我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python怎么编写PDF拆分工具

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python怎么编写PDF拆分工具

这篇文章主要介绍“Python怎么编写PDF拆分工具”,在日常操作中,相信很多人在Python怎么编写PDF拆分工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python怎么编写PDF拆分工具”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

需求

需要从 PDF 中取出几页并将其保存为新的 PDF,为了后期使用方便,这个工具需要做成傻瓜式的带有 GUI 页面的形式

Python怎么编写PDF拆分工具

选择源 pdf 文件,再指定下生成的新的 pdf 文件名称及保存位置,和需要拆分的 page 信息,就可以得到新的 pdf 文件了

需求解析

对于 Python GUI,我们有太多种选择了,下面我们先来横向的简单对比下

从高层次上看,大的 GUI 工具有:

  • Qt

  • WxWindows

  • Tkinter

  • Customer libraries(Kivy,Toga等)

  • Web相关(HTML,Flask等)

不过今天,我们选择的工具是 appJar,这是一个由一位从事教育工作的大神发明的,所以它可以提供一个更加简单的 GUI 创建过程,而且是完全基于 Tkinter 的,Python 默认支持

代码实现

首先为了实现 PDF 操作,我这里选择了 pypdf2 库

我们先硬编码一个输入输出的示例

from PyPDF2 import PdfFileWriter, PdfFileReaderinfile = "Input.pdf"outfile = "Output.pdf"page_range = "1-2,6"

接下来我们实例化 PdfFileWriter 和 PdfFIleReader 对象,并创建实际的 Output.pdf 文件

output = PdfFileWriter()input_pdf = PdfFileReader(open(infile, "rb"))output_file = open(outfile, "wb")

下面一个比较复杂的点就是需要拆分 pdf,提取页面并保存在列表中

page_ranges = (x.split("-") for x in page_range.split(","))range_list = [i for r in page_ranges for i in range(int(r[0]), int(r[-1]) + 1)]

最后就是从原始文件中拷贝内容到新的文件

for p in range_list:    output.addPage(input_pdf.getPage(p - 1))output.write(output_file)

下面来构建 GUI 界面

对于这个拆分 PDF 的小工具,需要具有如下功能:

  • 可以通过标准文件浏览器选择 pdf 文件

  • 可以选择输出文件的位置及文件名称

  • 可以自定义提取哪些页面

  • 有一些错误检查

通过 PIP 安装好 appJar 后,我们就可以编码了

from appJar import guifrom PyPDF2 import PdfFileWriter, PdfFileReaderfrom pathlib import Path

创建 GUI 窗口

app = gui("PDF Splitter", useTtk=True)app.setTtkTheme("default")app.setSize(500, 200)

这里我使用了默认主题,当然也可以切换各种各样的主题模式

Python怎么编写PDF拆分工具

下面是添加标签和数据输入组件

app.addLabel("Choose Source PDF File")app.addFileEntry("Input_File")app.addLabel("Select Output Directory")app.addDirectoryEntry("Output_Directory")app.addLabel("Output file name")app.addEntry("Output_name")app.addLabel("Page Ranges: 1,3,4-10")app.addEntry("Page_Ranges")

接下来添加按钮,“处理”和“退出”,按下按钮,调用如下函数

app.addButtons(["Process", "Quit"], press)

最后就是运行这个 app 啦

# start the GUIapp.go()

这样我们就完成了 GUI 的搭建,下面编写内部处理逻辑。程序读取任何输入,判断是否为 PDF,并拆分

def press(button):    if button == "Process":        class="lazy" data-src_file = app.getEntry("Input_File")        dest_dir = app.getEntry("Output_Directory")        page_range = app.getEntry("Page_Ranges")        out_file = app.getEntry("Output_name")        errors, error_msg = validate_inputs(class="lazy" data-src_file, dest_dir, page_range, out_file)        if errors:            app.errorBox("Error", "\n".join(error_msg), parent=None)        else:            split_pages(class="lazy" data-src_file, page_range, Path(dest_dir, out_file))    else:        app.stop()

如果单击 “处理(Process)”按钮,则调用 app.getEntry() 检索输入值,每个值都会被存储,然后通过调用 validate_inputs() 进行验证

来看看 validate_inputs 函数

def validate_inputs(input_file, output_dir, range, file_name):    errors = False    error_msgs = []    # Make sure a PDF is selected    if Path(input_file).suffix.upper() != ".PDF":        errors = True        error_msgs.append("Please select a PDF input file")    # Make sure a range is selected    if len(range) < 1:        errors = True        error_msgs.append("Please enter a valid page range")    # Check for a valid directory    if not(Path(output_dir)).exists():        errors = True        error_msgs.append("Please Select a valid output directory")    # Check for a file name    if len(file_name) < 1:        errors = True        error_msgs.append("Please enter a file name")    return(errors, error_msgs)

这个函数就是执行一些检查来确保输入有数据并且有效

在收集验证了所有数据后,就可以调用 split 函数来处理文件了

def split_pages(input_file, page_range, out_file):    output = PdfFileWriter()    input_pdf = PdfFileReader(open(input_file, "rb"))    output_file = open(out_file, "wb")    page_ranges = (x.split("-") for x in page_range.split(","))    range_list = [i for r in page_ranges for i in range(int(r[0]), int(r[-1]) + 1)]    for p in range_list:        # Need to subtract 1 because pages are 0 indexed        try:            output.addPage(input_pdf.getPage(p - 1))        except IndexError:            # Alert the user and stop adding pages            app.infoBox("Info", "Range exceeded number of pages in input.\nFile will still be saved.")            break    output.write(output_file)    if(app.questionBox("File Save", "Output PDF saved. Do you want to quit?")):        app.stop()

到此,关于“Python怎么编写PDF拆分工具”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python怎么编写PDF拆分工具

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python怎么编写PDF拆分工具

这篇文章主要介绍“Python怎么编写PDF拆分工具”,在日常操作中,相信很多人在Python怎么编写PDF拆分工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python怎么编写PDF拆分工具”的疑惑有所
2023-06-29

Python怎么利用PyPDF2快速拆分PDF文档

这篇文章主要讲解了“Python怎么利用PyPDF2快速拆分PDF文档”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python怎么利用PyPDF2快速拆分PDF文档”吧!目录安装PyPDF
2023-06-20

基于Python怎么编写微信清理工具

这篇“基于Python怎么编写微信清理工具”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于Python怎么编写微信清理工具
2023-06-30

怎么用python编写一个图片拼接工具

本文小编为大家详细介绍“怎么用python编写一个图片拼接工具”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用python编写一个图片拼接工具”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。代码展示这里写了两
2023-06-28

怎么使用Python代码实现一款永久免费PDF编辑工具

今天小编给大家分享一下怎么使用Python代码实现一款永久免费PDF编辑工具的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。P
2023-07-02

使用python怎么编写一个本地应用搜索工具

这篇文章主要介绍了使用python怎么编写一个本地应用搜索工具,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:python可以做什么Python是一种编程语言,内置了许多有效的工具,Pyt
2023-06-06

利用Python编写数据分析工具,实现精准市场营销

随着互联网时代的到来,商业竞争越来越激烈,市场营销愈发困难。营销人员需要启用更科学的手段,才能应对复杂多变的市场环境。其中,数据分析作为一种强有力的工具,被广泛应用于市场营销之中。下面,我们将介绍如何利用Python编写数据分析工具,实现精
利用Python编写数据分析工具,实现精准市场营销
2024-01-19

基于WPF怎么编写一个串口转UDP工具

这篇“基于WPF怎么编写一个串口转UDP工具”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于WPF怎么编写一个串口转UDP
2023-07-05

怎么使用Java工具类实现高效编写报表

本篇内容主要讲解“怎么使用Java工具类实现高效编写报表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用Java工具类实现高效编写报表”吧!为什么使用java代码写报表对于报表数据大部分情
2023-07-04

怎么通过Golang编写一个AES加密解密工具

本篇内容主要讲解“怎么通过Golang编写一个AES加密解密工具”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么通过Golang编写一个AES加密解密工具”吧!AES加密介绍及实现原理AES(
2023-06-30

利用Java怎么编写一个DES加密解密工具类

今天就跟大家聊聊有关利用Java怎么编写一个DES加密解密工具类,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。DesUtil.javapackage lsy;import java.
2023-05-31

怎么用python编写垃圾分类系统

编写垃圾分类系统可以利用Python的图像识别和机器学习库,以下是一个简单的实现思路:1. 数据收集:收集垃圾分类的图像数据集,包括有害垃圾、可回收物、湿垃圾和干垃圾。可以从开源数据集或者自行收集。2. 数据预处理:使用图像处理库(如Ope
2023-10-08

Python怎么实现多表和工作簿合并及一表按列拆分

今天小编给大家分享一下Python怎么实现多表和工作簿合并及一表按列拆分的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、相
2023-06-30

Python数据处理pandas读写操作IO工具CSV怎么使用

这篇“Python数据处理pandas读写操作IO工具CSV怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Pytho
2023-07-02

怎么使用Python工具分析Web服务器日志文件

这篇文章主要讲解了“怎么使用Python工具分析Web服务器日志文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Python工具分析Web服务器日志文件”吧!Lars 是 Pyth
2023-06-16

怎么使用Python编写一个简单的垃圾邮件分类器

这篇文章主要介绍“怎么使用Python编写一个简单的垃圾邮件分类器”,在日常操作中,相信很多人在怎么使用Python编写一个简单的垃圾邮件分类器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Pytho
2023-07-06

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录