Python中如何操作PDF文件?

来源:网站主作者:椎名光头衔:网络博主
导读:本期聚焦于小伙伴创作的《Python中如何操作PDF文件?》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Python中如何操作PDF文件?》有用,将其分享出去将是对创作者最好的鼓励。

在Python开发场景中,PDF文件的处理是常见需求,比如从PDF中提取文本、合并多个PDF、给PDF添加水印、生成自定义内容的PDF等,都可以通过对应的第三方库快速实现。

Python中如何操作PDF文件?

常用PDF操作库介绍

Python生态中有多个用于PDF操作的库,不同库的功能侧重不同,开发者可以根据需求选择:

  • PyPDF2:用于读取、合并、拆分、旋转PDF页面,提取PDF文本和元数据,是处理已有PDF的常用库。
  • reportlab:用于从零生成PDF文件,支持自定义文本、图片、表格、字体等内容的排版。
  • pdfplumber:专注于PDF文本和表格的提取,提取精度比PyPDF2更高,适合需要处理复杂排版PDF的场景。

读取PDF文本内容

如果只是需要提取PDF中的文本,使用PyPDF2就可以快速实现,首先需要通过pip安装该库:

pip install PyPDF2

以下是读取PDF所有页面文本的示例代码:

import PyPDF2

# 打开PDF文件,注意使用二进制读取模式
with open("test.pdf", "rb") as f:
    # 创建PDF读取器对象
    reader = PyPDF2.PdfReader(f)
    # 获取PDF总页数
    page_num = len(reader.pages)
    all_text = ""
    # 遍历所有页面提取文本
    for i in range(page_num):
        page = reader.pages[i]
        all_text += page.extract_text()
    print(all_text)

合并多个PDF文件

合并PDF也是常见需求,比如把多个单页PDF合并成一个完整的文档,使用PyPDF2的PdfMerger类可以快速实现:

import PyPDF2

# 创建合并器对象
merger = PyPDF2.PdfMerger()
# 需要合并的PDF文件路径列表
pdf_files = ["file1.pdf", "file2.pdf", "file3.pdf"]
# 依次添加所有PDF
for pdf in pdf_files:
    merger.append(pdf)
# 输出合并后的PDF
with open("merged.pdf", "wb") as f:
    merger.write(f)
merger.close()

生成自定义PDF文件

如果需要生成新的PDF文件,比如生成带标题、正文、图片的报表,可以使用reportlab库,安装命令如下:

pip install reportlab

以下是一个生成简单PDF的示例代码:

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

# 创建PDF画布,设置页面大小为A4
c = canvas.Canvas("generated.pdf", pagesize=A4)
# 设置字体和字号
c.setFont("Helvetica", 16)
# 绘制标题,参数依次为x坐标、y坐标、文本内容
c.drawString(100, 800, "这是生成的PDF标题")
# 设置正文字体
c.setFont("Helvetica", 12)
c.drawString(100, 770, "这是PDF的正文内容,可以通过drawString方法添加更多内容")
# 保存PDF文件
c.save()

给PDF添加水印

给PDF添加水印可以先用reportlab生成带水印的PDF,再用PyPDF2把水印合并到原PDF的每一页,示例代码如下:

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

# 第一步:生成水印PDF
watermark_canvas = canvas.Canvas("watermark.pdf", pagesize=A4)
watermark_canvas.setFont("Helvetica", 30)
watermark_canvas.setFillColorRGB(0.5, 0.5, 0.5, alpha=0.3)  # 设置灰色半透明
watermark_canvas.saveState()
watermark_canvas.translate(300, 400)  # 移动到页面中心
watermark_canvas.rotate(45)  # 旋转45度
watermark_canvas.drawString(0, 0, "内部资料")
watermark_canvas.restoreState()
watermark_canvas.save()

# 第二步:把水印合并到原PDF
with open("original.pdf", "rb") as original_f, open("watermark.pdf", "rb") as watermark_f:
    original_reader = PyPDF2.PdfReader(original_f)
    watermark_reader = PyPDF2.PdfReader(watermark_f)
    watermark_page = watermark_reader.pages[0]
    writer = PyPDF2.PdfWriter()
    # 遍历原PDF所有页面,合并水印
    for page in original_reader.pages:
        page.merge_page(watermark_page)
        writer.add_page(page)
    with open("watermarked.pdf", "wb") as out_f:
        writer.write(out_f)

注意事项

  • 操作PDF文件时,读取和写入都需要使用二进制模式,即rbwb模式,否则会出现文件损坏问题。
  • 部分加密的PDF需要先解密才能操作,PyPDF2的reader.decrypt("密码")方法可以实现解密。
  • 如果PDF是扫描件,提取文本前需要先做OCR识别,单纯用PDF库无法提取扫描件中的文字内容。

PythonPDF操作PyPDF2reportlab修改时间:2026-06-27 15:45:31

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。