目录

Python合并多个pdf

场景:

现在要解决批量合并PDF的问题。

有很多PDF文件需要合并成一个,比如报告、发票或者多个章节的文档。

对于Windows用户,Adobe Acrobat是专业的选择,但需要付费。但是我不想花钱,所以推荐免费软件,比如PDFsam Basic或者Smallpdf的桌面版。另外,PowerShell脚本的方法可能适合更技术型的用户,但普通用户可能觉得复杂。 WPS 得一个一个pdf 进行操作,实在麻烦。

Mac用户的话,预览应用的内置功能就很方便,不需要额外安装。但可能需要步骤指引,比如如何拖拽调整顺序,如何导出。如果用户需要更多功能,可能推荐在线工具或者第三方软件。

在线工具方面,ILovePDF、Smallpdf、PDFmerge都是不错的选择,但要提醒用户注意隐私问题,特别是处理敏感文档时。如果文件很多或者很大,上传下载可能会比较慢,这时候桌面软件更好。

还要考虑到用户可能遇到的问题,比如文件顺序不对,合并后的文件大小,或者格式混乱。

可能需要提醒用户提前按顺序命名文件。

为了简化,需要合并的PDF放在同一个文件夹,并按顺序合并。所以代码示例可能需要用户输入文件路径列表,或者自动合并某个文件夹中的所有PDF。

安装库

复制代码
pip install pypdf2    

python 代码

复制代码
import os
from PyPDF2 import PdfMerger

def merge_pdfs(input_folder, output_filename):
    merger = PdfMerger()
    
    # 获取文件夹中所有 PDF 文件并按名称排序
    pdf_files = [f for f in os.listdir(input_folder) if f.endswith(".pdf")]
    pdf_files.sort()  # 按文件名排序(可自定义排序逻辑)
    #pdf_files.sort(reverse=True)  # 按文件名排序(可自定义排序逻辑)
    
    # 逐个合并 PDF
    for pdf in pdf_files:
        file_path = os.path.join(input_folder, pdf)
        merger.append(file_path)
    
    # 输出合并后的文件
    merger.write(output_filename)
    merger.close()
    print(f"合并完成!保存为: {output_filename}")

# 使用示例
merge_pdfs(input_folder="你的PDF文件夹路径", output_filename="合并结果.pdf")

执行结果

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
长流小哥3 分钟前
Linux 深入浅出信号量:从线程到进程的同步与互斥实战指南
linux·c语言·开发语言·bash
予早3 分钟前
Python 冷门魔术方法
开发语言·python
databook11 分钟前
多变量决策树:机器学习中的“多面手”
python·机器学习·scikit-learn
linux kernel25 分钟前
Python基础语法2
开发语言·python
编程侦探31 分钟前
【设计模式】适配器模式:让不兼容的接口和谐共处
开发语言·c++·设计模式·适配器模式
互联网搬砖老肖43 分钟前
python成功解决AttributeError: can‘t set attribute ‘lines‘
开发语言·python
奋斗者1号1 小时前
深入解析 sklearn 中的 LabelEncoder:功能、使用场景与注意事项
人工智能·python·sklearn
CrawlerCracker1 小时前
小程序逆向|六六找房|请求头Authorization
javascript·爬虫·python·小程序·网络爬虫·js
张立龙6661 小时前
有序二叉树各种操作实现(数据结构C语言多文件编写)
c语言·开发语言·数据结构
2401_845417451 小时前
C++ string类
java·开发语言·c++