网络编程
位置:首页>> 网络编程>> Python编程>> python的​PyPDF2实现pdf文件切割和合并

python的​PyPDF2实现pdf文件切割和合并

作者:qq_29235677  发布时间:2023-02-07 19:57:39 

标签:python,PyPDF2,pdf

今天想使用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文件切割和合并

来源:https://blog.csdn.net/qq_29235677/article/details/122895023

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com