python的PyPDF2实现pdf文件切割和合并
程序员文章站
2022-03-02 11:36:42
今天想使用pdf的切分软件实现pdf文件的切分,但是软件需要会员???好吧,,,,又要会员,这么简单的功能能难倒咱们程序员吗。俗话说自给自足丰衣足食,决定使用python自己切分文件。在百度了一番后,...
今天想使用pdf的切分软件实现pdf文件的切分,但是软件需要会员???好吧,,,,又要会员,这么简单的功能能难倒咱们程序员吗。俗话说自给自足丰衣足食,决定使用python自己切分文件。
在百度了一番后,发现大多都是使用 adobe acrobat 软件进行剪裁,这完全不 pythonic,因此又找了用 python 处理 pdf 文件的方法,最后发现了 pypdf2 这个库,本文将利用这个库,实现对 pdf 的分割。
首先,你需要通过 pip 安装这个库:
pip install pypdf2
要使用python的
# 导入读写pdf模块 from pypdf2 import pdffilereader, pdffilewriter ''' 注意: 页数从0开始索引 range()是左闭右开区间 ''' def split_pdf(file_name, start_page, end_page, output_pdf): ''' :param file_name:待分割的pdf文件名 :param start_page: 执行分割的开始页数 :param end_page: 执行分割的结束位页数 :param output_pdf: 保存切割后的文件名 ''' # 读取待分割的pdf文件 input_file = pdffilereader(open(file_name, 'rb')) # 实例一个 pdf文件编写器 output_file = pdffilewriter() # 把分割的文件添加在一起 for i in range(start_page, end_page): output_file.addpage(input_file.getpage(i)) # 将分割的文件输出保存 with open(output_pdf, 'wb') as f: output_file.write(f) def merge_pdf(merge_list, output_pdf): """ merge_list: 需要合并的pdf列表 output_pdf:合并之后的pdf名 """ # 实例一个 pdf文件编写器 output = pdffilewriter() for ml in merge_list: pdf_input = pdffilereader(open(ml, 'rb')) page_count = pdf_input.getnumpages() for i in range(page_count): output.addpage(pdf_input.getpage(i)) output.write(open(output_pdf, 'wb')) if __name__ == '__main__': # 分割pdf split_pdf("test.pdf", 0, 3, "0-2.pdf") split_pdf("test.pdf", 7, 12, "7-11.pdf") split_pdf("test.pdf", 18, 23, "18-22.pdf") split_pdf("test.pdf", 27, 33, "26-32.pdf") split_pdf("test.pdf", 40, 44, "40-43.pdf") split_pdf("test.pdf", 46, 51, "46-50.pdf") split_pdf("test.pdf", 58, 66, "58-65.pdf") split_pdf("test.pdf", 77, 84, "77-83.pdf") split_pdf("test.pdf", 93, 97, "93-96.pdf") split_pdf("test.pdf", 102, 106, "102-105.pdf") # 合并pdf # 合并的pdf列表 pdf_list = ["0-2.pdf", "7-11.pdf", "18-22.pdf", "26-32.pdf", "40-43.pdf", "46-50.pdf", "58-65.pdf", "77-83.pdf", "93-96.pdf", "102-105.pdf"] merge_pdf(pdf_list, "all.pdf")
下面是切分好的文件效果,完美
到此这篇关于python的pypdf2实现pdf文件切割和合并的文章就介绍到这了,更多相关python pypdf2实现pdf剪裁内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!