Python:合并两个PDF文件为一个PDF

如果你使用PyPDF2'遇到了 AttributeError: partially initialized module 'PyPDF2' has no attribute 'PdfFileReader' 这个错误,可能是由于 PyPDF2 库的版本问题或者库本身的问题。在这种情况下,你可以尝试使用 PyMuPDF(MuPDF)库来处理 PDF 文件。以下是一个使用 PyMuPDF 的示例代码:

首先,你需要安装 PyMuPDF 库:

bash 复制代码
pip install pymupdf

接下来,使用以下示例代码来合并两个 PDF 文件:

python 复制代码
import fitz  # PyMuPDF

def merge_pdfs(pdf1_path, pdf2_path, output_path):
    # 打开两个 PDF 文件
    pdf1 = fitz.open(pdf1_path)
    pdf2 = fitz.open(pdf2_path)

    # 创建新的 PDF 文档
    merged_pdf = fitz.open()

    # 将第一个 PDF 文件的页面添加到新文档
    for page_num in range(pdf1.page_count):
        page = pdf1[page_num]
        merged_pdf.insert_pdf(pdf1, from_page=page_num, to_page=page_num, start_at=merged_pdf.page_count)

    # 将第二个 PDF 文件的页面添加到新文档
    for page_num in range(pdf2.page_count):
        page = pdf2[page_num]
        merged_pdf.insert_pdf(pdf2, from_page=page_num, to_page=page_num, start_at=merged_pdf.page_count)

    # 保存合并后的 PDF 到输出文件
    merged_pdf.save(output_path)

    # 关闭所有打开的 PDF 文件
    pdf1.close()
    pdf2.close()
    merged_pdf.close()

# 使用示例
pdf1_path = 'path/to/first.pdf'
pdf2_path = 'path/to/second.pdf'
output_path = 'path/to/output.pdf'

merge_pdfs(pdf1_path, pdf2_path, output_path)

替换 path/to/first.pdfpath/to/second.pdf 为你的实际文件路径,将合并后的 PDF 文件保存到 path/to/output.pdf。这个示例使用 PyMuPDFfitz 模块来实现 PDF 合并。

相关推荐
Ven%1 小时前
【AI大模型算法工程师面试题解析与技术思考】
人工智能·python·算法
天勤量化大唯粉1 小时前
枢轴点反转策略在铜期货中的量化应用指南(附天勤量化代码)
ide·python·算法·机器学习·github·开源软件·程序员创富
Swizard1 小时前
拒绝“狗熊掰棒子”!用 EWC (Elastic Weight Consolidation) 彻底终结 AI 的灾难性遗忘
python·算法·ai·训练
Spider赵毅1 小时前
python实战 | 如何使用海外代理IP抓取Amazon黑五数据
python·tcp/ip·php
月光技术杂谈1 小时前
基于Python的网络性能分析实践:从Ping原理到自动化监控
网络·python·性能分析·ping·时延·自动化监控
龘龍龙1 小时前
Python基础学习(四)
开发语言·python·学习
maogewang2 小时前
清朝条约全集 PDF 电子版(三册合集):从尼布楚到辛丑条约的完整史料集
pdf
洵有兮2 小时前
python第四次作业
开发语言·python
kkoral2 小时前
单机docker部署的redis sentinel,使用python调用redis,报错
redis·python·docker·sentinel
BoBoZz192 小时前
IterativeClosestPoints icp配准矩阵
python·vtk·图形渲染·图形处理