今天我们继续分享真实的自动化办公案例,希望各位 Python 爱好者能够从中得到些许启发,在自己的工作生活中更多的应用 Python,使得工作事半功倍!

需求

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

选择源 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 gui
from PyPDF2 import PdfFileWriter, PdfFileReader
from pathlib import Path

创建 GUI 窗口

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

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

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

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 GUI
app.go()

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

def press(button):if button == "Process":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(src_file, dest_dir, page_range, out_file)if errors:app.errorBox("Error", "\n".join(error_msg), parent=None)else:split_pages(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 = Falseerror_msgs = []# Make sure a PDF is selectedif Path(input_file).suffix.upper() != ".PDF":errors = Trueerror_msgs.append("Please select a PDF input file")# Make sure a range is selectedif len(range) < 1:errors = Trueerror_msgs.append("Please enter a valid page range")# Check for a valid directoryif not(Path(output_dir)).exists():errors = Trueerror_msgs.append("Please Select a valid output directory")# Check for a file nameif len(file_name) < 1:errors = Trueerror_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 indexedtry:output.addPage(input_pdf.getPage(p - 1))except IndexError:# Alert the user and stop adding pagesapp.infoBox("Info", "Range exceeded number of pages in input.\nFile will still be saved.")breakoutput.write(output_file)if(app.questionBox("File Save", "Output PDF saved. Do you want to quit?")):app.stop()

好了,这样我们就完成了一个简易的 GUI 拆分 PDF 文件的工具喽

Python自动化办公之PDF拆分工具相关推荐

  1. 好用到爆的Python自动化办公教程pdf,Python × Excel × Word × PPT 一次搞定

    在这个自动化时代,我们有很多重复无聊的工作要做.想想这些你不再需要一次又一次地做的无聊的事情,让它自动化,让你的生活更轻松.那么在本文中,我将向您介绍一个好用到爆的Python自动化办公教程pdf,P ...

  2. Python 自动化办公之 Excel 对比工具

    作者 | 周萝卜 来源丨萝卜大杂烩 今天我们继续分享真实的自动化办公案例,希望各位 Python 爱好者能够从中得到些许启发,在自己的工作生活中更多的应用 Python,使得工作事半功倍! 需求 由于 ...

  3. Python自动化办公之Excel对比工具

    今天我们继续分享真实的自动化办公案例,希望各位 Python 爱好者能够从中得到些许启发,在自己的工作生活中更多的应用 Python,使得工作事半功倍! 需求 由于工作当中经常需要对比前后两个 Exc ...

  4. Python 自动化办公之 Excel 拆分并自动发邮件

    作者 | 周萝卜 来源 | 萝卜大杂烩 今天我们来分享一个真实的自动化办公案例,希望各位 Python 爱好者能够从中得到些许启发,在自己的工作生活中更多的应用 Python,使得工作事半功倍! 需求 ...

  5. Python自动化办公之Excel拆分并自动发邮件

    今天我们来分享一个真实的自动化办公案例,希望各位 Python 爱好者能够从中得到些许启发,在自己的工作生活中更多的应用 Python,使得工作事半功倍! 需求 需要向大约 500 名用户发送带有 E ...

  6. Python自动化办公:pdf文档操作

    在后台回复[阅读书籍] 即可获取python相关电子书~ Hi,我是山月. 之前给大家介绍了python处理excel.word.ppt的相关教程,不知道大家学的怎么样? 在后台回复[自动化办公]即可 ...

  7. Python自动化办公【PDF文件自动化】

    PDF 文件可以分为可编辑型PDF 文件与扫描型PDF 文件,内容可以复制,是可编辑型PDF文件,反之则是扫描型PDF 文件.简单理解扫描型PDF文件是由一张张图像构建而成. 读取PDF文件内容 1. ...

  8. Python自动化办公:PDF批量处理(打水印、加密码、分类放置)

    在日常工作中,要保护一下我们的商业机密嘛~ 如果按名单向客户逐一发文件,如果就发几份,那么可以采取用pdf软件逐份编辑,打个水印.加个密码咯.但面对成百上千份文件,就需要批量处理了!菜鸡在熬夜加班后终 ...

  9. 【python自动化办公】Python自动化之pdf——PyPDF2、pdfplumber、fitz、pdf2image库介绍

    目录 前言 1. 学习python自动化办公目的 2. 未来持续打卡内容 3. 资料来源与思维导图 一.PDF处理库 1.PyPDF2--基础操作 2.pdfplumber--表格抽取 3.fitz- ...

最新文章

  1. 项目导入时报错:The import javax.servlet.http.HttpServletRequest cannot be resolved
  2. QML范围和命名分辨率
  3. 第三方提权之serv-u提权
  4. 太监式的自主知识产权研发特色 (Z)
  5. java 泛型 类型形参(Type Parameters) 类型
  6. 从EF三层 到 DDD领域驱动设计(1)--------------数据操作
  7. delphi7 调用XE编译的DLL遇到的坑
  8. python中delay__python delay函数
  9. 二维码扫码登录原理详解
  10. 中国期货市场监控中心爬虫
  11. Validation 参数校验
  12. 阿里P7亲自教你!2021Java不死我不倒
  13. 鲁迅朱安:留给世纪的背影_拔剑-浆糊的传说_新浪博客
  14. 阿里云CDN介绍以及如何配合OSS使用
  15. 展望下未来的计算机400字,展望未来的作文400字
  16. linux ubuntu实验
  17. 文明游戏5的计算机配置,文明5和文明6哪个好玩 文明5最低电脑配置要求
  18. 2021-07-12测绘资质新标准和旧标准改革内容
  19. 2019清华计算机考研名单,2019清华大学研究生硕士考研拟录取名单
  20. M - 魔戒(四维BFS)

热门文章

  1. UnicodeEncodeError: ‘ascii‘ codec can‘t encode character ‘\u4eba‘ in position 15:问题解决
  2. Vue.js 数据展示全部和收起
  3. 跳板机的基本原理,以及实现思路!
  4. 无法找到打印机microsoft xps document writer
  5. 电脑双屏显示器小工具UltraMon
  6. 中科爱讯WiFi探针在贵宾客户提醒领域的应用
  7. 关于称重系统,你知道这六点吗?
  8. 电子学——第002课:基础知识(电阻、电压、电流)
  9. cs223w课程笔记7-GNN2
  10. 手持话筒测试软件,无线麦克风有哪些测试方法