【Python】PDF文件处理(PyPDF2、borb、fitz)

Python提供了多种方法和库用于处理PDF文件,这些工具可以帮助开发者实现诸如读取、写入、合并、拆分以及压缩等功能。以下是几个常用的Python PDF操作库及其基本用法(PyPDF2、borb、fitz)。

1. PyPDF2

PyPDF2 是一个功能强大的库,支持各种常见的PDF操作,例如读取、合并、分割、旋转页面等。尽管该库已经停止更新,但它仍然被广泛使用。

bash 复制代码
pip install pypdf2

下面是一个简单的例子展示如何使用 PyPDF2 合并两个PDF文件:

python 复制代码
import os
from PyPDF2 import PdfMerger

merger = PdfMerger()
files = ["file1.pdf", "file2.pdf"]

for file in files:
    if os.path.exists(file):
        merger.append(file)
    
merger.write("merged_file.pdf")
merger.close()

2. borb

borb 是另一个现代且易于使用的PDF库,它允许用户创建、修改现有的PDF文档,并提供了一些高级特性如加密和签名。以下是如何打开现有PDF文件并保存更改的一个示例:

bash 复制代码
pip install borb
python 复制代码
from borb.pdf.reader import SimplePDFReader
from borb.pdf.document import Document
from borb.pdf.writer import Writer

# 打开已有PDF文件
with open("example.pdf", "rb") as pdf_in:
    reader = SimplePDFReader(pdf_in)
    doc: Document = reader.read()

# 修改文档 (此处省略具体修改逻辑)

# 将修改后的文档另存为新文件
with open("output.pdf", "wb") as pdf_out:
    writer = Writer(pdf_out, doc)
    writer.write()

3. fitz (PyMuPDF)

fitz(也称为 PyMuPDF)能够高效地解析复杂的PDF结构,适合于需要提取图像或者文本的应用场景。此外,它还可以用来转换整个PDF成图片序列。

bash 复制代码
pip install pymupdf

示例代码如下所示:

python 复制代码
import fitz  # 导入模块

# 加载目标pdf
doc = fitz.open('input.pdf')

# 遍历每一页并将它们转为png格式
for page_num in range(len(doc)):
    page = doc.load_page(page_num)
    pix = page.get_pixmap(dpi=300)
    output_filename = f'page_{page_num}.png'
    pix.save(output_filename)

4. 处理大尺寸PDF的技术手段

对于较大的PDF文件,可以通过以下几种技术减少其体积:

  • 图片质量调整:降低分辨率或将高清晰度的照片替换为较低版本;
  • 字体优化:移除未使用的字符集或完全不嵌入字体数据;
  • 清理冗余项:去除隐藏层、空白页码区域以及其他无意义的内容;
相关推荐
m0_734949795 小时前
MySQL如何配置定时清理过期备份文件_find命令与保留周期策略
jvm·数据库·python
m0_514520575 小时前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
H Journey5 小时前
Python 国内pip install 安装缓慢
python·pip·install 加速
Polar__Star6 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
m0_743623927 小时前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python
FreakStudio7 小时前
无硬件学LVGL—定时器篇:基于Web模拟器+MicroPython速通GUI开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
gCode Teacher 格码致知8 小时前
Python提高:pytest的简单案例-由Deepseek产生
python·pytest
不要秃头的小孩8 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
科雷软件测试8 小时前
使用python+Midscene.js AI驱动打造企业级WEB自动化解决方案
前端·javascript·python
weipt8 小时前
发票打印还在花钱?这款免费小工具,A4纸一半大小、自动排版,真香!
pdf·发票打印