python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python PyMuPDF处理PDF文档

Python通过PyMuPDF高效处理PDF文档的操作方法

作者:Asia-Lee

PyMuPDF(又称 fitz)是一个功能强大的Python库,用于处理PDF、XPS、EPUB、MOBI等文档格式,它基于MuPDF(轻量级 PDF 渲染引擎),提供高效的文本提取、渲染、编辑和文档分析功能,所以本文给大家介绍了Python通过PyMuPDF高效处理PDF文档的操作方法

一、PyMuPDF 核心功能

文本提取

文档渲染

文档操作

高级特性

pip install PyMuPDF

二、关键代码示例

1. 打开文档 & 提取文本

import fitz  # PyMuPDF 的导入名称

# 打开 PDF
doc = fitz.open("document.pdf")

# 提取第一页文本
page = doc.load_page(0)
text = page.get_text()
print(text)

# 按区块提取(保留位置信息)
blocks = page.get_text("blocks")
for block in blocks:
    print(block[4])  # 文本内容(block格式: (x0, y0, x1, y1, text))

2. 渲染页面为图像

# 渲染为 PNG
pix = page.get_pixmap(matrix=fitz.Matrix(2, 2))  # 缩放2倍
pix.save("page0.png")

# 指定 DPI (300 dpi)
dpi = 300
mat = fitz.Matrix(dpi / 72, dpi / 72)  # 72是默认DPI
pix = page.get_pixmap(matrix=mat)

3. 编辑 PDF

# 添加文本到新页面
new_page = doc.new_page(width=400, height=200)
new_page.insert_text((100, 50), "Hello PyMuPDF!", fontsize=24)

# 绘制红色矩形
rect = fitz.Rect(50, 70, 150, 120)
new_page.draw_rect(rect, color=(1, 0, 0), width=2)

# 保存修改
doc.save("modified.pdf")

4. 合并 PDF

doc1 = fitz.open("doc1.pdf")
doc2 = fitz.open("doc2.pdf")

# 将 doc2 插入到 doc1 末尾
doc1.insert_pdf(doc2)
doc1.save("merged.pdf")

5. 提取图像

for img_index, img in enumerate(page.get_images(full=True)):
    xref = img[0]  # 图像引用 ID
    base_image = doc.extract_image(xref)
    image_bytes = base_image["image"]
    with open(f"image_{img_index}.png", "wb") as f:
        f.write(image_bytes)

6. 搜索文本

# 搜索所有 "important" 出现的位置
areas = page.search_for("important")
for rect in areas:
    page.add_highlight_annot(rect)  # 添加高亮注释

三、相关说明

1. 性能优势

2. 适用场景

3. 注意事项

  1. 安装依赖:无需额外依赖(Windows/macOS/Linux 均有预编译包)
  2. 加密文档:使用 doc.authenticate(password) 处理密码
  3. 坐标系:原点在左上角(与传统 PDF 坐标一致)
  4. 商业许可:AGPL 协议(商业应用需购买许可证)

以上就是Python通过PyMuPDF高效处理PDF文档的操作方法的详细内容,更多关于Python PyMuPDF处理PDF文档的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文