有时候我们只需要pdf中的几页,或许还想把这几页内容整合成新的pdf,那该怎么做呢?
创新互联建站-专业网站定制、快速模板网站建设、高性价比市中网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式市中网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖市中地区。费用合理售后完善,10余年实体公司更值得信赖。
准备工作:
安装扩展库PyPDF2,参考命令
pip install PyPDF2
代码如下:
from PyPDF2 import PdfFileReader, PdfFileWriter def split_pdf(filename, result, start=0, end=None): """从filename中提取[start,end)之间的页码内容保存为result""" # 打开原始 pdf 文件 pdf_src = PdfFileReader(filename) if end is None: # 获取页数 end = pdf_src.getNumPages() with open(result, "wb") as fp: # 创建空白pdf文件 pdf = PdfFileWriter() # 提取页面内容,写入空白文件 for num in range(start, end): pdf.addPage(pdf_src.getPage(num)) # 写入结果pdf pdf.write(fp) fn = r"G:\a001\第九天.pdf" split_pdf(fn, "1.pdf", 0, 3) split_pdf(fn, "2.pdf", 1, 3) split_pdf(fn, "3.pdf", 2, 3)
遇见的问题一:
Traceback (most recent call last): File "G:/a001/pdf.py", line 22, insplit_pdf(fn, "1.pdf", 0, 3) File "G:/a001/pdf.py", line 7, in split_pdf pdf_src = PdfFileReader(filename) File "E:\project_luffy\luffy\lib\site-packages\PyPDF2\pdf.py", line 1084, in __init__ self.read(stream) File "E:\project_luffy\luffy\lib\site-packages\PyPDF2\pdf.py", line 1901, in read raise utils.PdfReadError("Could not find xref table at specified location") PyPDF2.utils.PdfReadError: Could not find xref table at specified location
还没有找到好的解决问题的办法,但是我在操作过程中换了一个新的pdf文件就成功了,猜测是你的pdf文件出了问题。
遇见的问题二:
在解决了上面的问题之后,程序可以正常的使用,但是还会出一个问题:
PdfReadWarning: Xref table not zero-indexed. ID numbers for objects will be corrected. [pdf.py:1736]
虽然不影响,但是体验不好啊 ,继续解决吧
import sys if not sys.warnoptions: import warnings warnings.simplefilter("ignore")
上面代码要加在最上面
关于PyPDF2的内容,昨天有详细讲解过,不会的小伙伴可以查看:进阶PDF,就用Python(PyPDF2模块)
(推荐操作系统:windows7系统、Python 3.9.1,DELL G3电脑。)
名称栏目:创新互联Python教程:Python中用PyPDF2拆分pdf提取页面
文章分享:http://www.shufengxianlan.com/qtweb/news15/509365.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联