PDF 拆分/合并

虚幻大学 xuhss 198℃ 0评论

? 优质资源分享 ?

学习路线指引(点击解锁) 知识定位 人群定位
? Python实战微信订餐小程序 ? 进阶级 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
?Python量化交易实战? 入门级 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

不会真的有人会去下载那些广告免费,实则要收会员费的黑心软件来进行PDF的拆分合并吧???

在下载两个均不能免费实现PDF自由拆分、合并,以及PDF打印方式会增加文件大小的情况下,一个合格的程序员肯定不能向不良商家低头,所以使用PyPDF2实现这些功能,并给大家分享一个简单、易用、易懂的python小程序。

from PyPDF2 import PdfFileReader, PdfFileMerger, PdfFileWriter

def merge(input1,input2,output):

 file\_merger = PdfFileMerger()
 file\_merger.append(input1)
 file\_merger.append(input2)
 file\_merger.write(output)

def split(input,output,start\_page, end\_page):
 try:
 read\_file = input
 fp\_read\_file = open(read\_file, 'rb')
 pdf\_input = PdfFileReader(fp\_read\_file)  # 将要分割的PDF内容格式话
        page\_count = pdf\_input.getNumPages()  # 获取PDF页数
        print("该文件共有{}页".format(page\_count))  # 打印页数

        try:
 print(f'开始分割{start\_page}页-{end\_page}页,保存为{output}......')
 pdf\_output = PdfFileWriter()  # 实例一个 PDF文件编写器
            for i in range(start\_page, end\_page):
 pdf\_output.addPage(pdf\_input.getPage(i))
 with open(output, 'wb') as sub\_fp:
 pdf\_output.write(sub\_fp)
 print(f'完成分割{start\_page}页-{end\_page}页,保存为{output}!')
 except IndexError:
 print(f'分割页数超过了PDF的页数')
 # fp.close()
    except Exception as e:
 print(e)

if \_\_name\_\_ == '\_\_main\_\_':
 input1 = open(r"1.pdf", "rb") #打开第一个PDF文件
    input2 = open(r"2.pdf", "rb") #打开第二个PDF文件
    output=r'submit.pdf'
 merge(input1,input2,output)

 # input = r"submit.pdf" #打开第二个PDF文件
    # output= r'1.pdf'
    # split(input,output,9,35) # start 起始页 从0 开始算,end 是尾页从1开始算

转载请注明:xuhss » PDF 拆分/合并

喜欢 (0)

您必须 登录 才能发表评论!