PDF文件格式

如今,可移植文档格式(PDF)属于最常用的数据格式。在1990年,PDF文档的结构由Adobe定义。PDF格式的思想是,对于通信过程中涉及的双方(创建者,作者或发送者以及接收者)而言,传输的数据/文档看起来完全相同。

工具和库

适用于Python的PDF工具,模块和库的可用解决方案范围有些混乱,需要花一点时间弄清楚什么是什么,以及哪些项目需要连续维护。根据我们的研究,以下是最新的候选人:

  • PyPDF2:一个Python库,用于提取文档信息和内容,逐页拆分文档,合并文档,裁剪页面并添加水印。PyPDF2支持未加密和加密的文档。

  • PDFMiner:完全用Python编写,适用于Python 2.4。对于Python 3,请使用克隆的包PDFMiner.six。这两个软件包都允许您解析,分析和转换PDF文档。这包括对PDF 1.7以及CJK语言(中文,日文和韩文)的支持,以及各种字体类型(Type1,TrueType,Type3和CID)。

  • pdflib for Python:Poppler库的扩展,为它提供了Python绑定。它使您可以解析,分析和转换PDF文档。不要将其与具有相同名称的商业吊坠相混淆。

  • PyFPDF:一个在Python下生成PDF文档的库。从FPDF PHP库移植而来,这是著名的PDFlib扩展替换,其中包含许多示例,脚本和派生类。

  • PDFTables:一项商业服务,提供从PDF文档附带的表格中提取的内容。提供一个API,以便PDFTables可以用作SAAS。

  • PyX -Python图形包:PyX是用于创建PostScript,PDF和SVG文件的Python包。它结合了PostScript绘图模型的抽象和TeX / LaTeX接口。这些基元可以构建复杂的任务,例如以可发布的质量创建2D和3D绘图。

  • ReportLab:一个雄心勃勃的,具有行业实力的图书馆,主要致力于精确创建PDF文档。免费提供开放源代码版本和名为ReportLab PLUS的商业增强版本。

  • PyMuPDF(又称“ fitz”):MuPDF的Python绑定,这是一种轻量级的PDF和XPS查看器。该库可以访问PDF,XPS,OpenXPS,epub,漫画和小说书格式的文件,并且以其最佳性能和高渲染质量而闻名。

  • pdfrw:一个基于Python的纯PDF解析器,用于读写PDF。它忠实地再现矢量格式而无需光栅化。与ReportLab结合使用时,它有助于在使用ReportLab创建的新PDF中重用现有PDF的一部分。

图书馆 用于
PyPDF2
PyMuPDF
pdflib
PDF表格
PDFMiner.six
PDF查询
pdfrw 读,写/创作
PyFPDF 写/创作

我们将重点介绍PyPDF2和PyMuPDF,并说明如何以最简单的方式提取文本和图像。为了了解PyPDF2的用法,官方文档和许多其他资源提供的示例的组合对您有所帮助。相比之下,官方PyMuPDF文档更加清晰,并且使用该库的速度也大大加快。

使用PyPDF2提取文本

$ pip3 install PyPDF2

清单1首先导入了PdfFileReader该类。接下来,使用该类打开文档,并使用getDocumentInfo()方法提取文档信息,使用提取页数getDocumentInfo()以及第一页的内容。

请注意,PyPDF2从0开始计数页面,这就是该调用pdf.getPage(0)检索文档第一页的原因。最终,提取的信息被打印到stdout

清单1:提取文档信息和内容。

#!/usr/bin/pythonfrom PyPDF2 import PdfFileReaderpdf_document = "example.pdf"
with open(pdf_document, "rb") as filehandle:pdf = PdfFileReader(filehandle)info = pdf.getDocumentInfo()pages = pdf.getNumPages()print (info)print ("number of pages: %i" % pages)page1 = pdf.getPage(0)print(page1)print(page1.extractText())

如上面的图1所示,提取的文本是连续打印的。没有段落或句子分隔。如PyPDF2文档中所述,所有文本数据都按照在页面内容流中提供的顺序返回,并且依靠它可能会导致一些意外。这主要取决于PDF文档的内部结构,以及PDF编写器过程如何生成PDF指令流。

使用PyMuPDF提取文本

可从PyPi网站上获取PyMuPDF,并在终端中使用以下命令安装软件包:

$ pip3 install PyMuPDF

显示文档信息,打印页数以及提取PDF文档的文本的方式与PyPDF2相似(请参见清单2)。要导入的模块名为fitz,并返回到PyMuPDF的先前名称。

清单2:使用PyMuPDF从PDF文档中提取内容。

#!/usr/bin/pythonimport fitzpdf_document = "example.pdf"
doc = fitz.open(pdf_document)
print ("number of pages: %i" % doc.pageCount)
print(doc.metadata)page1 = doc.loadPage(0)
page1text = page1.getText("text")
print(page1text)

PyMuPDF的优点是可以保持原始文档结构完整-带有换行符的整个段落都保留在PDF文档中(参见图2)。

使用PyMuPDF从PDF提取图像

PyMuPDF使用该方法简化了从PDF文档提取图像的过程getPageImageList()清单3基于PyMuPDF Wiki页面上的示例,并逐页地将PDF中的所有图像提取并保存为PNG文件。如果图像具有CMYK色彩空间,则将首先将其转换为RGB。

清单3:提取图像

#!/usr/bin/pythonimport fitzpdf_document = fitz.open("file.pdf")
for current_page in range(len(pdf_document)):for image in pdf_document.getPageImageList(current_page):xref = image[0]pix = fitz.Pixmap(pdf_document, xref)if pix.n < 5:        # this is GRAY or RGBpix.writePNG("page%s-%s.png" % (current_page, xref))else:                # CMYK: convert to RGB firstpix1 = fitz.Pixmap(fitz.csRGB, pix)pix1.writePNG("page%s-%s.png" % (current_page, xref))pix1 = Nonepix = None

在400页PDF上运行此Python脚本,它在不到3秒的时间内提取了117张图像,这真是了不起。单个图像以PNG格式存储。为了保持原始图像的格式和大小,而不是转换为PNG,请查看PyMuPDF Wiki中脚本的扩展版本。

使用PyPDF2将PDF拆分为页面

对于此示例,首先需要同时导入PdfFileReader和和PdfFileWriter类。然后,我们打开PDF文件,创建一个阅读器对象,并使用阅读器对象的getNumPages方法遍历所有页面。

for循环内部,我们创建的新实例PdfFileWriter,该实例尚不包含任何页面。然后,使用pdfWriter.addPage()方法将当前页面添加到我们的writer对象。此方法接受一个页面对象,我们使用该PdfFileReader.getPage()方法获取该对象。

下一步是创建一个唯一的文件名,我们使用原始文件名加上单词“ page”以及页码来完成。我们在当前页码上加1,因为PyPDF2会计算从零开始的页码。

最后,我们以“写二进制”模式(mode wb)打开新文件名,并使用该类的write()方法pdfWriter将提取的页面保存到磁盘。

清单4:将PDF拆分为单个页面。

#!/usr/bin/pythonfrom PyPDF2 import PdfFileReader, PdfFileWriterpdf_document = "example.pdf"
pdf = PdfFileReader(pdf_document)for page in range(pdf.getNumPages()):pdf_writer = PdfFileWriter()current_page = pdf.getPage(page)pdf_writer.addPage(current_page)outputFilename = "example-page-{}.pdf".format(page + 1)with open(outputFilename, "wb") as out:pdf_writer.write(out)print("created", outputFilename)

查找所有包含文本的页面

这个用例非常实用,并且工作方式类似于pdfgrep。该脚本使用PyMuPDF返回包含给定搜索字符串的所有页码。页面一页接一页地加载,借助该searchFor()方法,将检测到搜索字符串的所有出现情况。如果匹配则在上面印有相应的信息stdout

清单5:搜索给定的文本。

#!/usr/bin/pythonimport fitzfilename = "example.pdf"
search_term = "invoice"
pdf_document = fitz.open(filename):for current_page in range(len(pdf_document)):page = pdf_document.loadPage(current_page)if page.searchFor(search_term):print("%s found on page %i" % (search_term, current_page))

下面的图5显示了一本400页的书中“ Debian GNU / Linux”一词的搜索结果。

结论

此处显示的处理PDF方法非常强大。使用相对较少的代码行数,很容易获得结果。

Python操作PDF-文本和图片提取(使用PyPDF2和PyMuPDF)相关推荐

  1. python操作pdf做文档的分割、合并,内容提取

    Python 操作 PDF 会用的库:PyPDF2 和 pdfplumber PyPDF2 可以更好的读取.写入.分割.合并PDF文件: pdfplumber 可以更好的读取 PDF 文件中内容和提取 ...

  2. python提取pdf中的文字和图片_Python操作PDF-文本和图片提取(使用PyPDF2和PyMuPDF)...

    PDF文件格式 如今,可移植文档格式(PDF)属于最常用的数据格式.在1990年,PDF文档的结构由Adobe定义.PDF格式的思想是,对于通信过程中涉及的双方(创建者,作者或发送者以及接收者)而言, ...

  3. python 生成pdf 文字和图片_Python系列—PDF文本与图片抽取

    PDF是人们日常使用最多的跨平台文档.其是一种用独立于应用程序.硬件.操作系统的方式呈现文档的文件格式.每个PDF文件包含固定布局的平面文档的完整描述,包括文本.字形.图形及其他需要显示的信息.具有良 ...

  4. task04 办公自动化之Python 操作 PDF

    # 基本库导入 import pandas as pd import numpy as np 1.相关库了解 利用python操作pdf会用到两个库,分别是:PyPDF2 和 pdfplumber 其 ...

  5. python怎么玩pdf_最全总结!聊聊 python 操作PDF的几种方法

    作者:陈熹 来源:早起Python 一.前言 大家好,有关Python操作PDF的案例之前已经写过一个PDF批量合并,这个案例初衷只是给大家提供一个便利的脚本,并没有太多讲解原理,其中涉及的就是PDF ...

  6. Python 操作 PDF 的几种方法

    作者 | 陈熹 来源 | 早起Python(ID:zaoqi-python) 头图 |  CSDN 下载自视觉中国 前言 大家好,有关 Python 操作 PDF 的案例之前已经写过一个????PDF ...

  7. Python将PDF转成图片—PyMuPDF和pdf2image

    前言:在最近的测试中遇到一个与PDF相关的测试需求,其中有一个过程是将PDF转换成图片,然后对图片进行测试. 粗略的试了好几种方式,其中语言尝试了Python和Java,总体而言所找到的Python方 ...

  8. pdf转换成jpg python_【PyMuPDF和pdf2image】Python将PDF转成图片PNG和JPG

    公众号:前言:在最近的测试中遇到一个与PDF相关的测试需求,其中有一个过程是将PDF转换成图片,然后对图片进行测试. 粗略的试了好几种方式,其中语言尝试了Python和Java,总体而言所找到的Pyt ...

  9. 【PyMuPDF和pdf2image】Python将PDF转成图片

    2023-04-30更新 PyMuPDF=1.21.1 import datetime # PyMuPDF=1.21.1 import fitzdef pdf2img(pdf_path, img_pa ...

最新文章

  1. Vue封装一个简单轻量的上传文件组件
  2. 蓝桥杯_算法训练_大小写转换
  3. 软件工程概论 课堂练习【图书馆系统的用例图】
  4. filter过滤后重新添加_每天记一个单词(第3518)filter
  5. [补档]暑假集训D5总结
  6. 【今日CV 计算机视觉论文速览 第130期】Thu, 13 Jun 2019
  7. frameset标签设计页面
  8. java map 容器_java容器-map的常用实现及原理
  9. 简单机器学习系统的构建以及对于不对称性的分类介绍和性能评价
  10. Python中requests上传大文件
  11. Chrome浏览器扩展:bilibili哔哩哔哩视频下载助手 2.1.5_0
  12. python怎么过滤标点符号大全_python 过滤标点符号
  13. Hijack攻击揭秘
  14. 硬盘插上后提示“设备未就绪”の解决方案
  15. 在Excel中插入行并复制单元格格式
  16. 程序人生--2003年(20)
  17. C++多线程同时读同一文件
  18. 让人面到崩溃的特斯拉.NET工程师面试题
  19. 大数据技术与应用实训心得_数据实习心得
  20. 2020年科协第二次硬件培训总结

热门文章

  1. android api 完整通译之Contacts Provider (学习安卓必知的api,中英文对照)
  2. 两个数据库服务器怎么删除一个文件夹,删除公用文件夹数据库
  3. mutations vuex 调用_Vuex的mutations与actions使用详解
  4. 一场发生在餐厅里的电子***战
  5. 消息队列及常见消息队列介绍
  6. [SV]SystemVerilog中forever begin end導致的Hang死
  7. oracle 序列缓存的作用,Oracle序列sequence 深入理解
  8. [日推荐]『宝可梦图鉴』精灵宝可梦的百科全书
  9. 正交实验测试用例利器——pict
  10. count(*),count(1),count(列)区别