5 种使用Python自动化处理PDF的实用方法介绍

 更新时间:2025年09月26日 15:12:12   作者:E-iceblue  
自动化处理 PDF 文件已成为减少重复工作、提升工作效率的重要手段,本文将介绍五种实用方法,从内置工具到专业库,帮助你在 Python 中实现 PDF 任务的自动化

自动化处理 PDF 文件已成为减少重复工作、提升工作效率的重要手段。对于需要处理报表、合同或发票的开发者来说,手动操作往往耗时且容易出错。Python 因其简单易用且拥有丰富生态系统,提供了多种库,使得 PDF 的拆分、合并、提取和生成等操作变得更加便捷。本文将介绍五种实用方法,从内置工具到专业库,帮助你在 Python 中实现 PDF 任务的自动化。

使用内置库(os、subprocess)调用外部工具

在 Python 中,标准库如 ossubprocess 并不直接支持 PDF 操作,但你仍可以利用它们调用外部命令行工具,从而完成基本的 PDF 操作,例如合并、拆分或转换文件。下面的示例演示如何借助命令行工具将 PDF 文件转换为 .txt 文档:

import subprocess
import os

input_path = r"E:/Administrator/Python1/input/AI绘画的利与弊-图片版.pdf"
output_path = r"E:/Administrator/Python1/output/转为TXT.pdf"

# 调用命令行工具 pdftotext
subprocess.run(["pdftotext", input_path, output_path])

if os.path.exists(output_path):
    print("文本提取成功:", output_path)

注意:此代码依赖 Windows 下的第三方命令行工具 Poppler。

使用 PyPDF2 进行基本 PDF 操作

在了解了 Python 内置库之后,我们来看最受欢迎的开源 Python PDF 库之一——PyPDF2。这个轻量级且广泛使用的库,可以方便地完成常见 PDF 操作,如合并多个文件、拆分文档、旋转页面以及提取文本。对于只需进行基础 PDF 操作的开发者来说,它是一个很好的起点,无需依赖繁重的外部工具。

下面的代码示例展示了如何使用 PyPDF2 拆分 PDF,并将前两页保存为新的 PDF 文件:

from PyPDF2 import PdfReader, PdfWriter

input_path = r"E:/Administrator/Python1/input/AI绘画的利与弊-图片版.pdf"
output_path = r"E:/Administrator/Python1/output/拆分PDF.pdf"

# 创建 PdfReader 对象并读取源 PDF
reader = PdfReader(input_path)

# 创建 PdfWriter 对象
writer = PdfWriter()

# 拆分 PDF,并将前两页添加到 writer
for i in range(2):  
    writer.add_page(reader.pages[i])

# 将拆分后的 PDF 写入新文件
with open(output_path, "wb") as f:
    writer.write(f)

print("拆分后的 PDF 已生成:", output_path)

以下为拆分后的 PDF 与原文档的对比预览:

使用 pdfplumber 精准提取文本

PDF 文件通常难以直接编辑,因此许多人希望提取其中的内容(如文本或表格)以便在其他场景中复用。这时 pdfplumber 就非常实用。它是专门用于文本和表格提取的开源 Python 库,能够在保持原有结构的同时提供高度准确的提取结果,非常适合需要可靠数据提取的场景。

下面的示例展示如何使用 pdfplumber 从 PDF 中提取文本并输出到控制台:

import pdfplumber

input_path = r"/input/AI绘画的利与弊-图片版.pdf"

with pdfplumber.open(input_path) as pdf:
    page = pdf.pages[1]
    text = page.extract_text()
    print("第一页提取的文本:\n", text)

使用 ReportLab 创建和定制 PDF

到目前为止,我们主要关注的是从现有 PDF 文档中提取或转换内容,或拆分页面。除了处理已有文件外,许多场景还需要动态生成 PDF 文档,例如自动生成报表、添加水印或插入图表和图片。ReportLab 是一个强大的 Python 库,允许开发者从零创建 PDF 文件,并对内容和布局进行高度定制。借助 ReportLab,你可以轻松生成个性化 PDF,以满足各种业务或展示需求。

下面的 Python 示例展示如何使用 ReportLab 创建 PDF 文件:

from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import A4

output_path = r"/output/生成PDF.pdf"

c = canvas.Canvas(output_path, pagesize=A4)
c.drawString(100, 750, "this is a PDF created using ReportLab.")
c.drawString(100, 730, "You can add text, images and even tables.")
c.showPage()
c.save()

print("新 PDF 已生成:", output_path)

以下为输出文件预览:

使用专业库如 Spire.PDF 应对高级场景

除了开源库外,Python 还有商业选项,例如 Spire.PDF for Python,它提供了全面的功能,涵盖几乎所有常见的 Adobe Acrobat 操作,如 PDF 加密、数字签名和格式转换。同时,它还支持一些 Acrobat 难以处理的高级任务,如批量表单字段处理、生成带复杂图表的动态 PDF 以及自动化 PDF 报告创建。对于需要专业、自动化且高度定制的 PDF 处理工作,Spire.PDF 提供了灵活高效的解决方案。

下面通过两个代码示例展示 Spire.PDF 在 Python 中的应用。

以下示例演示如何为 PDF 文件添加数字签名:

from spire.pdf.common import *
from spire.pdf import *

# 加载 PDF
doc = PdfDocument()
doc.LoadFromFile("/input/Booklet.pdf")

# 创建签名生成器
signatureMaker = PdfOrdinarySignatureMaker(doc, "/alice.pfx", "e-iceblue")

# 配置签名属性,如签名者姓名、联系方式、位置和签名原因
signature = signatureMaker.Signature
signature.Name = "Alice"
signature.ContactInfo = "+86 12345678"
signature.Location = "China"
signature.Reason = "Author"

# 创建自定义签名外观
appearance = PdfSignatureAppearance(signature)
appearance.NameLabel = "Signer: "
appearance.ContactInfoLabel = "Tel: "
appearance.LocationLabel = "Address:"
appearance.ReasonLabel = "Reason: "
appearance.SignatureImage = PdfImage.FromFile("/signature2.png")
appearance.GraphicMode = GraphicMode.SignImageAndSignDetail
appearance.SignImageLayout = SignImageLayout.none

# 获取首页
page = doc.Pages[0]

# 将签名添加到页面指定位置
signatureMaker.MakeSignature("Alice sign", page, 90.0, 600.0, 260.0, 100.0, appearance)

# 保存已签名文档
doc.SaveToFile("/output/数字签名.pdf")
doc.Close()

结果预览:

以下示例展示如何使用打开密码和权限密码加密 PDF:

from spire.pdf.common import *
from spire.pdf import *

# 加载 PDF 文件
doc = PdfDocument()
doc.LoadFromFile("/input/AI绘画的利与弊-图片版.pdf")

# 使用打开密码和权限密码加密 PDF
doc.Security.Encrypt("openPsd", "permissionPsd", PdfPermissionsFlags.FillFields, PdfEncryptionKeySize.Key128Bit)

doc.SaveToFile("/output/加密PDF.pdf", FileFormat.PDF)

总结

总的来说,Python 提供了丰富的解决方案来处理 PDF,从满足基础需求的开源库到针对复杂工作流提供高级功能的商业工具。根据项目需求——无论是简单的文本提取、文档转换,还是构建完整的自动化 PDF 工作流——开发者都可以选择最适合的方案,在功能性、易用性和性能之间找到最佳平衡。

到此这篇关于5 种使用Python自动化处理PDF的实用方法介绍的文章就介绍到这了,更多相关Python自动化处理PDF内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python机器学习之基础概述

    Python机器学习之基础概述

    今天带大家回顾python机器学习的相关知识,文中非常详细的介绍了Python机器学习的基础概述,算法分类及研究内容,需要的朋友可以参考下
    2021-05-05
  • Python面向对象中类(class)的简单理解与用法分析

    Python面向对象中类(class)的简单理解与用法分析

    这篇文章主要介绍了Python面向对象中类(class)的简单理解与用法,结合实例形式分析了Python面向对象程序设计中类(class)的基本概念、原理、定义与使用方法,需要的朋友可以参考下
    2020-02-02
  • Python设计模式之代理模式实例

    Python设计模式之代理模式实例

    这篇文章主要介绍了设计模式中的代理模式Python实例,需要的朋友可以参考下
    2014-04-04
  • Python face_recognition实现AI识别图片中的人物

    Python face_recognition实现AI识别图片中的人物

    最近碰到了照片识别的场景,正好使用了face_recognition项目,给大家分享分享。face_recognition项目能做的很多,人脸检测功能也是有的,是一个比较成熟的项目。感兴趣的可以了解一下
    2022-01-01
  • python使用openpyxl打开及读取excel表格过程

    python使用openpyxl打开及读取excel表格过程

    openpyxl是一个Python库,用于读写Excel 2010 xlsx/xlsm文件,它允许你轻松工作与Excel表格,进行数据处理和分析,支持读取、创建和修改Excel文件,甚至可以在Excel中插入图表等,安装非常简单,只需要使用pip命令即可
    2024-09-09
  • django接入新浪微博OAuth的方法

    django接入新浪微博OAuth的方法

    这篇文章主要介绍了django接入新浪微博OAuth的方法,实例分析了django针对新浪微博OAuth接口的接入技巧,需要的朋友可以参考下
    2015-06-06
  • 教你用Python查看茅台股票交易数据的详细代码

    教你用Python查看茅台股票交易数据的详细代码

    CSV是以逗号分隔数据项(也被称为字段)的数据交换格式,主要应用于电子表格和数据库之间的数据交换,本文给大家介绍下用Python查看茅台股票交易数据的详细代码,感兴趣的朋友一起看看吧
    2022-03-03
  • Python 对数字的千分位处理方式

    Python 对数字的千分位处理方式

    这篇文章主要介绍了Python 对数字的千分位处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • python如何通过注册表动态管理组件

    python如何通过注册表动态管理组件

    使用注册表的主要优势是可以在运行时动态创建对象,从而实现高度可配置和可扩展的设计,这篇文章主要介绍了python如何通过注册表动态管理组件,需要的朋友可以参考下
    2024-05-05
  • python实现飞机大战小游戏

    python实现飞机大战小游戏

    这篇文章主要为大家详细介绍了python实现飞机大战游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11

最新评论