决定自己写个 Python 程序实现这个需求,前面自己动手实现过 Word 转 PDF ,现在再搞一个 PDF 转 Word 吧。

于是,去 Pypi 官网搜索一下是否存在类似 pdf2word、pdf2doxc 等名称的第三方库,果然发现了一个 pdf2doxc,而且安装、入门示例、API 文档也很详细,赶紧去学习下吧!

经过一番研究,这个依赖库有三种转换方式可以选择使用,下面逐一介绍下:

1、写代码实现

支持将PDF所有页进行转换,也支持指定页的转换。

<1>. 转换PDF所有页

from pdf2docx import Converter
from pdf2docx import parse

# 测试用例1
pdf_filename = 'D:\\XXX\\简历-wxx.pdf'
docx_filename_all = 'D:\\XXX\\简历-wxx_all.docx'

"""默认转换pdf所有页"""

# 方式1:
parse(pdf_filename, docx_filename_all)

# 方式2:
# pdf = Converter(pdf_filename)
# pdf.convert(docx_filename_all)
# pdf.close()

转换过程中,日志如下:

Python把PDF转成word python pdf转换成word_2d

<2>. 转换PDF指定页

from pdf2docx import Converter

# 测试用例1
pdf_filename = 'D:\\XXX\\简历-wxx.pdf'
docx_filename_part = 'D:\\XXX\\简历-wxx_part.docx'

"""
转换pdf指定页(比如:只转换第三页到第五页):
    start=0表示第一页,end=5表示第六页但不包括
"""
pdf = Converter(pdf_filename)

# 方式1:使用start~end参数,转换前两页简历,start=0可省略
pdf.convert(docx_filename_part, start=0, end=2)

# 方式2:使用pages参数
# pdf.convert(docx_filename_part, pages=[2, 3, 4])

pdf.close()

转换效果如下:(两页的简历)

Python把PDF转成word python pdf转换成word_pdf2doxc_02

2、命令行模式

这种方式不用编码,但需要熟悉命令行的书写方式,可以通过 help 查看下 pdf2docx 命令的用法:

Python把PDF转成word python pdf转换成word_2d_03

<1>. 转换PDF所有页

Python把PDF转成word python pdf转换成word_PDF转Word_04

<2>. 转换PDF指定页

方式1,通过start、end参数,转换第二页到第三页

Python把PDF转成word python pdf转换成word_pdf2doxc_05

方式2,通过pages参数,转换第二页和第三页

Python把PDF转成word python pdf转换成word_pdf2doxc_06

转换效果如下:

Python把PDF转成word python pdf转换成word_办公自动化_07

 3、GUI界面模式

通过命令 pdf2docx gui 调出 GUI 界面进行转换,操作步骤如下:

Python把PDF转成word python pdf转换成word_办公自动化_08

总结

至此,通过 pdf2doxc 已经实现了我的 PDF 转 Word 需求,实现效果也很棒!另外,如果再深入一点的话,会有这么几个问题值得思考:

  • 如果 PDF 是加密类型的怎么办?
  • 如果PDF含有大量的图片,表格、代码块等特殊区域是否也可以完美转换呢?

<1>. 加密场景转换

查看 API 文档可知,通过 Converter() 函数加入打开 PDF 文档的密码参数password

Python把PDF转成word python pdf转换成word_2d_09

<2>. 含有大量的图片,表格、代码块等特殊区域的场景转换

这里,有一篇111页的学习笔记,存在着大量的特殊区域,测试一下转换效果~

from pdf2docx import Converter

# 测试用例
pdf_filename = 'D:\\XXX\\SpringBoot经典学习笔记.pdf'
docx_filename_all = 'D:\\XXX\\SpringBoot经典学习笔记_all.docx'
docx_filename_part = 'D:\\XXX\\SpringBoot经典学习笔记_part_3.docx'

pdf = Converter(pdf_filename)
pdf.convert(docx_filename_all)
pdf.close()

效果如下:

Python把PDF转成word python pdf转换成word_PDF转Word_10

有些没有转换过来,成为了空白页!!通过控制台输出信息可以看到:出现错误时,当前页不会转换输出的。

Python把PDF转成word python pdf转换成word_2d_11

该问题主要是 PDF 存在无法识别的特殊区域导致的,因此,PDF的内容尽量不要太复杂,不要太花里胡哨。通常情况下,pdf2doxc 库已经可以满足常见的转换需求了。

最后,Pypi官网还能搜索到 pdfminer、pdfminer1、pdfminer2、pdfminer3、pdfminer3k 等 PDF 转换/分析器的第三方库,看着都混乱,这里不再考虑使用这些库了,感兴趣的话可以再研究研究~