使用Python自由切分pdf文件提取任意页面

 这个小知识来自公众号【python小屋】

 

问题描述:

给定一个PDF文件,对其进行任意切分,提取其中任意页面,保存为新的PDF文件。

准备工作:

安装扩展库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, in <module>
    split_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")

  

上面代码要加在最上面

posted @   流年中渲染了微笑  阅读(930)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
历史上的今天:
2019-09-27 Python 内置类型 dict, list,线程安全吗
2018-09-27 vue学习(二)Vue常用指令
2018-09-27 vue学习(一)ES6常用语法
点击右上角即可分享
微信分享提示