Python实现多个pdf文件合并

Python实现多个pdf文件合并

背景

由于工作原因,经常需要将多个pdf文件合并后打印,有时候上网找免费合并工具比较麻烦(公司内网不能访问公网),于是决定搞个小工具。

具体实现

需要安装 PyPDF2

pip install PyPDF2

代码

# -*- coding=utf-8 -*-
"""
功能: 将当前目录下的所有pdf文件合并为一个文件,新文件命名为 all_merge_年月日_时分秒.pdf
被合并的pdf文件不包含 all_merge 开头的文件
"""

import PyPDF2
import pathlib
import datetime


def do_merge(the_dir):
    prefix = 'all_merge'
    output_file = '%s_%s.pdf' % (prefix, datetime.datetime.now().strftime('%Y%m%d_%H%M%S'))

    pdf_files = []
    path_dir = pathlib.Path(the_dir)
    for filename in path_dir.iterdir():
        if not filename.is_file():
            continue
        if filename.name[0:len(prefix)] == prefix:
            continue
        elif filename.name.endswith('.pdf'):
            pdf_files.append(filename.name)

    pdf_files.sort(key=str.lower)
    pdf_writer = PyPDF2.PdfFileWriter()
    print("find %d pdf file(s)." % len(pdf_files))
    idx = 0
    for f in pdf_files:
        idx += 1
        print("%d: %s" % (idx, f))
        pdf_obj = open(f, 'rb')
        pdf_reader = PyPDF2.PdfFileReader(pdf_obj)
        for page_num in range(0, pdf_reader.numPages):
            page_obj = pdf_reader.getPage(page_num)
            pdf_writer.addPage(page_obj)

    pdf_output = open(output_file, 'wb')
    pdf_writer.write(pdf_output)
    pdf_output.close()
    print("merge file:[ %s ]" % output_file)
    input("Press any key to exit.")


if __name__ == "__main__":
    do_merge(".")

效果

合并处理效果

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值