知行编程网知行编程网  2022-10-21 13:30 知行编程网 隐藏边栏  30 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于Python中用PyPDF2拆分pdf提取页面的相关知识,包括pdf单页导出,以及pdf如何拆分页面这些编程知识,希望对大家有参考作用。

有时我们只需要pdf中的几页,也许我们想将这些页面整合到一个新的pdf中,那么我们应该怎么做呢?



准备工作:


安装扩展库PyPDF2,参考命令

<p><span>pip install PyPDF2<br/></span></p>


代码如下:

<p><span>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)<br/></span></p>



遇见的问题一:

<p><span>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<br/></span></p>


还没有找到好的解决问题的办法,但是

我在操作过程中换了一个新的pdf文件就成功了,猜测是你的pdf文件出了问题。



遇见的问题二:

解决以上问题后,程序可以正常使用了,但是还是有一个问题:

<p><span>PdfReadWarning: Xref table not zero-indexed. ID numbers for objects will be corrected. [pdf.py:1736]<br/></span></p>


虽然不影响,但是体验不好啊 ,继续解决吧

<p><span>import sys
 
if not sys.warnoptions:
    import warnings
    warnings.simplefilter("ignore")<br/></span></p>



上面代码要加在最上面

关于PyPDF2的内容,我昨天已经详细讲解过了,不懂的可以去看看:


(推荐操作系统:windows7系统、Python 3.9.1,DELL G3电脑。)

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享