只用40行Python代码就能写出pdf转word小工具
作者:程序员启航 发布时间:2021-11-03 18:02:00
一、图示
上面为pdf截图内容,下面为转化后的word截图内容
接下来,我们试试自己动作写这个工具吧!
二、前期准备
由于我们采用的是python
进行工具编写,并最终需要打包成一个exe
文件供我们使用。为了降低包体大小,我们需要先创建一个虚拟环境
备用。
另外,pdf转word有现成的第三方库pdf2docx
,同时关于gui我们用的是pysimplegui
,打包成exe采用的是pyinstaller
。在创建虚拟环境后,我们将这些需要用到的第三方库也一一安装吧。
# 创建虚拟环境
conda create -n env_pdf python=3.8.8
# 激活虚拟环境
conda activate env_pdf
# 安装三个库
pip install pdf2docx
pip install pysimplegui
pip install pyinstaller
关于这三个库,大家可以查阅官方文档了解更多:
pdf2word : https://dothinking.github.io/pdf2docx/index.html
pysimplegui:https://pysimplegui.readthedocs.io/en/latest/
pyinstaller:http://www.pyinstaller.org/
前期准备工具就绪,我们开始进入工具编写阶段。
三、pdf转word
pdf转word感觉是一个存在已久的话题,现在其实市面上很多工具可以使用,不过完全免费的可能需要认真找找。
我们知道python有很多处理pdf文档的第三方库以及处理word的第三方库,所以有人就将这两类库的功能进行了整合,从而有了今天的主角pdf2docx
。
基本思路:
利用
PyMuPDF
获取页面元素,例如文本和形状及其位置再利用元素间的相对位置关系推断内容
最后使用
python-docx
将上一步解析的内容元素重建为docx格式的Word文档
基于以上情况,咱们这个工具在进行操作的时候会存在以下不足:
无法识别和重建PDF扫描件
根据有限的、确定的规则建立PDF与docx元素之间的映射并非完全可靠,也就是说仅能处理常见的规范的格式,而非百分百还原
当然,以上这些我们都不用管,直接参考官方给到的代码即可:
from pdf2docx import Converter
import re
# 传入文件绝对路径
def pdf_to_word(fileName):
pdf_file = fileName
# 正则获取不含文件类型后缀的部分,用于组成word文档绝对路径
name = re.findall(r'(.*?)\.',pdf_file)[0]
docx_file = f'{name}.docx'
cv = Converter(pdf_file)
cv.convert(docx_file, start=0, end=None)
cv.close()
其中,start
和end
参数指定待转换pdf文档的页码范围(默认是从0开始到最后一页);也可以通过pages
指定不连续的页面,例如pages=[1,3,5]
。
四、GUI设计
关于pdf转word的功能,我们需要的就是选择待转化的文件、开始转化即可,另外记录一下操作流让我们知道进度就完美了。所以,功能其实很简单,我们基于以上功能设计简单的GUI如下:
ue设计手稿
由于我们这次用到的是pysimplegui
这个超级简单好用的工具库,那么为了满足以上功能,编码如下(思路见注释)。
import PySimpleGUI as sg
import re
# 主题设置
sg.theme('DarkTeal7')
# 布局设置
layout = [
[sg.Text('待转化的文件是:',font=("微软雅黑", 12)),sg.Text('',key='filename',size=(50,1),font=("微软雅黑", 10),text_color='blue')],
[sg.Text('程序操作记录',justification='center')],
[sg.Output(size=(80, 20),font=("微软雅黑", 10))],
[sg.FileBrowse('选择文件',key='file',target='filename'),sg.Button('开始转化'),sg.Button('关闭程序')]
]
# 创建窗口
window = sg.Window('pdf转word工具,作者@微信公众号:可以叫我才哥', layout,font=("微软雅黑", 15),default_element_size=(50,1))
# 事件循环
while True:
event, values = window.read()
if event in (None, '关闭程序'):
break
if event == '开始转化':
if values['file'] and re.findall(r'\.(\S+)',values['file'])[0]=='pdf':
fileName = values['file']
pdf_to_word(fileName)
print('\n----------转化完毕----------\n')
else:
print('文件未选取或文件非pdf文件\n请先选择文件')
window.close()
不得不说,确实会比PyQt5
要来的简单。
sg.theme('DarkTeal7')
是设置gui的主题,pysimplegui提供很多主题,大家可以自由选择;
layout
就是设置布局,具体我们根据UE手稿需求从上到下依次设置:
sg.Text()
设置文本内容和格式sg.Output()
设置print输出的地方sg.FileBrowse()
设置文件选择浏览器,key
是指定健名称,target
是选定的文件夹名sg.Button()
设置按钮sg.Window()
是创建窗口,可以带窗口名称等信息
event
和values
是当执行window.read()
函数时的返回值:其中event
是事件,如点击按钮、选择文件等;values
是包含输入的值,比如我们选择文件后的文件名信息值。
结合之前的pdf转word函数,这里的逻辑如下:
当我们点击开始转化按钮,先判断是否选择了pdf文件,如果是则执行转化函数,否则就提示文件未选择或选择的非pdf文件。
五、打包代码
这里采用的是pyinstaller进行程序代码打包,操作指令如下:
pyinstaller -F -w pdf转word小工具.py
部分参数含义:
-F 表示生成单个可执行文件
-w 表示去掉控制台窗口,这在GUI界面时非常有用
-p 表示你自己自定义需要加载的类路径,一般情况下用不到
-i 表示可执行文件的图标
其实,最新版本的word(office2019)已经天然支持对非扫描版pdf的读取和转化了,大家通过以下流程进行处理:文档—>打开—>选择待转化pdf文件
即可。
office-word自带转化功能
来源:https://blog.csdn.net/aaahtml/article/details/117279793


猜你喜欢
- 1、注意:pool必须在 if __name__ == '__main__' 下面运行,不然会报错2、多进程内出现错误会直接
- using System;using System.Collections.Generic;using System.Text;using
- 刷新本地缓存Ctrl+Shift+R查询select *from [table]修改1、普通更新UPDATE [table] set [字段
- def quick_sort(ls): return [] if ls == [] else quick_sort([y for y in
- 如下所示:import rec = re.compile(r'\d')s = 'you1are2welcome
- 实现打包功能~轻松方便!压缩比虽比winrar差那么一点 但是也没啥关系 毕竟只打包做下载 省下了自己去服务器上把站点打
- 应用场景:实验中不断得到新数据,想将数据图形化,但随着时间推移,数据越来越多,此时需要我们等距选择数据列表中固定数量的数据,来进行图形化。注
- #创建触发器,当往order表中添加记录是,更新goods表 delimiter $ CREATE TRIGGER trigger1 AFT
- 一、什么是系统调用In computing, a system call is the programmatic way in which
- 在过去的十年中,MySQL已经成为广受欢迎的数据库,而WordPress博客使用的是MySQL数据库,虽然使用插件可以解决一些问题,但是实现
- 热力图热力图(Heat Map)是指用 X 轴 和 Y 轴 表示的两个分类字段确定数值点的位置,通过相应位置的矩形颜色去表现数值的大小,颜色
- re.group()用法在正则表达式中,re.group()方法是用来提取出分组截获的字符串,匹配模式里的括号用于分组。举例说明:#!/us
- 首先需求一共有五次猜测机会,在五次机会中才对就赢了,结束游戏,五次都猜错就输了,也结束游戏。首先先画个草图,这是我画的草图再根据草图编写一个
- 如何检测某个对象是否有某个属性?第一想到的——没错,in:"prop" in obj这很完美,不过,还有不少人热衷下面的
- 一、Base64编码原理步骤1:将所有字符转化为ASCII码;步骤2:将ASCII码转化为8位二进制;步骤3:将二进制3个归成一组(不足3个
- 一、安装Docker安装环境:系统:CentOS Linux7 x86_64安装脚本wget -qO- https://get.docker
- 上图效果,动态添加绑定radio选项,然后也可以动态删除,右边编辑器删除,左边的视图也对应的删除。视图代码 view:"<u
- 前言在一个分布式环境中,每台机器上可能需要启动和停止多个进程,使用命令行方式一个一个手动启动和停止非常麻烦,而且查看每个进程的状态也很不方便
- SQLite是一种嵌入式数据库,它的数据库就是一个文件。由于SQLite本身是C写的,而且体积很小,所以,经常被集成到各种应用程序中,甚至在
- <?php /* *文件名:linearList.php * 功能:数据结构线性表的顺序存储实现 * author:黎锦焕 * @co