Python3,区区9行代码批量提取PDF文件的指定内容,我被震惊了....

简介: 有了此方法,再也不需要手抄PDF文档了。

1、引言

小屌丝:鱼哥, 你有没有什么办法,提取PDF文档的内容。

小鱼:这个还问我??

小屌丝:哎呀,这个不是被难住了嘛 。

小鱼:有啥难得?提示你一下,

小屌丝:嗯,可以可以。

小鱼:去我的博文找,没记错的话,有两种方法提取pdf的文字。

小屌丝:好嘞, 我这就去…找找…

2000.jpg

小屌丝:鱼哥,鱼哥~

小鱼:怎么样,你的这个需求,解决了吧。

小屌丝:没呢,我想批量提取指定PDF文档的内容…

小鱼:批…量…

小屌丝:对啊,是批量,

小鱼:这…还挺…

小屌丝:挺费劲吗?

小鱼:挺好的 ,不费劲, 一口气,上7楼…

小屌丝:打住… 说正事! !

小鱼:好嘞…


想到提取PDF文件的内容,我们第一反应就是pypdf,

因为pypdf这个库我在很多篇文章都介绍过, 还蛮好用的。

但是,今天,我们不使用pypdf,而是使用另一个库,即:pdfminer。

sa.png


2、代码实战

2.1 介绍

pdfminer我相信很多同学都没听说过,除非,你经常提取/解析PDF文件的内容,否则,你对ta,只能是陌生。


其实,提取PDF文件内容解决方案,截止到现在, 只有pypdf 和pdfminer这两种。

所以, 如果你厌倦了, pypdf,那只能选择pdfminer了。


那什么是pdfminer 呢,或者 pdfminer有什么神奇之处呢?


  • 定义
  • PDFMiner是用于从PDF文档提取信息的工具;
  • 与其他PDF相关工具不同,它完全专注于获取和分析文本数据;
  • 功能
  • PDFMiner允许获取页面中文本的确切位置以及其他信息,例如字体或线条;
  • 它包括一个PDF转换器,可以将PDF文件转换为其他文本格式(例如HTML);

2.2 安装

由于pdfminer是python 的第三方库, 所以,需要安装,

老规矩, 直接pip 安装

安装


pipinstallpdfminer


安装完成

image.png


因为我们需要用到 pdfminer的high_level 方法,所以

这里必须要在安装pdfminer.six模块,否则会报错:


安装

pipinstallpdfminer.six


安装完成

image.png


其它安装方式,直接看这两篇:


2.3 实例

安装完成,我们就来写上代码,

我们先来捋顺一下思路,主要分3步:


  • 1、遍历pdf文件

注:如果文件夹的文件多个,需要单独提取目标pdf文件,否则都会轮巡匹配,费事费力费资源;

  • 2、提取pdf文档内容
  • 3、根据正则匹配,提取需要的文档信息

我们就根据这个思路,来提取"企业基本情况",代码如下:


代码示例

# -*- coding:utf-8 -*-# @Time   : 2022-12-10# @Author : Carl_DJfrompdfminerimporthigh_levelimportre,os#pdf文件路径#root:文件夹路径,dirs:文件夹下子目录名,files:文件夹下的文件forroot,dirs,filesinos.walk('./data/'):
#遍历pdf文件forfinfiles:
file_name=os.path.join(root,f)
iffile_name.endswith('.pdf'):
#提取整个 pdf 文本信息text=high_level.extract_text(file_name)
#提取 pdf文档中 "企业进本情况:" 后面的信息,利用正则进行匹配regex=r'企业基本情况-(.*?)\n'qy_base=re.findall(regex,text)
print(f'输出信息:{qy_base}')




pdf文件

image.png

运行结果

61.png


3、总结

看到这里,今天的分享,差不多就该结束了。

解析PDF是一件非常耗时和耗内存的工作,因此,pdfminer使用一种称作Lazy Parsing的策略,减少内耗…

小屌丝:怪不得, 提到批量提取pdf的文档内容, 你会犹豫了…

小鱼:对啊,因为我们的的测试文档内容很少,所以对内存的消耗相对来说没那么验证,当PDF文档的内容很多时, 就不得不使用pdfminer了。


并且, 关于pdf文档的内容提取,我们能多学习几个技能,就多学习几个技能。


技能多了,路就多了,最后,收入也就多了


我是小鱼


  • CSDN 博客专家;
  • 阿里云社区 专家博主;
  • 51CTO博客 专家博主&TOP红人
  • 51认证讲师;
  • 金牌面试官;


关注我,带你学习更多更有趣的Python知识。


目录
相关文章
|
2月前
|
数据可视化 Linux iOS开发
Python脚本转EXE文件实战指南:从原理到操作全解析
本教程详解如何将Python脚本打包为EXE文件,涵盖PyInstaller、auto-py-to-exe和cx_Freeze三种工具,包含实战案例与常见问题解决方案,助你轻松发布独立运行的Python程序。
822 2
|
3月前
|
安全 JavaScript 开发者
Python 自动化办公神器|一键转换所有文档为 PDF
本文介绍一个自动化批量将 Word、Excel、PPT、TXT、HTML 及图片转换为 PDF 的 Python 脚本。支持多格式识别、错误处理与日志记录,适用于文档归档、报告整理等场景,大幅提升办公效率。仅限 Windows 平台,需安装 Office 及相关依赖。
171 0
|
1月前
|
监控 机器人 编译器
如何将python代码打包成exe文件---PyInstaller打包之神
PyInstaller可将Python程序打包为独立可执行文件,无需用户安装Python环境。它自动分析代码依赖,整合解释器、库及资源,支持一键生成exe,方便分发。使用pip安装后,通过简单命令即可完成打包,适合各类项目部署。
|
2月前
|
机器学习/深度学习 文字识别 Java
Python实现PDF图片OCR识别:从原理到实战的全流程解析
本文详解2025年Python实现扫描PDF文本提取的四大OCR方案(Tesseract、EasyOCR、PaddleOCR、OCRmyPDF),涵盖环境配置、图像预处理、核心识别与性能优化,结合财务票据、古籍数字化等实战场景,助力高效构建自动化文档处理系统。
545 0
|
3月前
|
程序员 数据安全/隐私保护 Python
1行Python代码,实现PDF的加密、解密
程序员晚枫分享使用python-office库实现PDF批量加密与解密的新方法。只需一行代码,即可完成单个或多个PDF文件的加密、解密操作,支持文件路径与正则筛选,适合自动化办公需求。更新至最新版,适配性更佳,操作更简单。
146 8
1行Python代码,实现PDF的加密、解密
|
4月前
|
C#
【PDF提取内容改名】批量提取PDF指定区域内容重命名PDF文件,PDF自动提取内容命名的方案和详细步骤
本工具可批量提取PDF中的合同编号、日期、发票号等关键信息,支持PDF自定义区域提取并自动重命名文件,适用于合同管理、发票处理、文档归档和数据录入场景。基于iTextSharp库实现,提供完整代码示例与百度、腾讯网盘下载链接,助力高效处理PDF文档。
595 40
|
3月前
|
缓存 数据可视化 Linux
Python文件/目录比较实战:排除特定类型的实用技巧
本文通过四个实战案例,详解如何使用Python比较目录差异并灵活排除特定文件,涵盖基础比较、大文件处理、跨平台适配与可视化报告生成,助力开发者高效完成目录同步与数据校验任务。
138 0
|
4月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
3月前
|
监控 Linux 数据安全/隐私保护
Python实现Word转PDF全攻略:从入门到实战
在数字化办公中,Python实现Word转PDF自动化,可大幅提升处理效率,解决格式兼容问题。本文详解五种主流方案,包括跨平台的docx2pdf、Windows原生的pywin32、服务器部署首选的LibreOffice命令行、企业级的Aspose.Words,以及轻量级的python-docx+pdfkit组合。每种方案均提供核心代码与适用场景,并涵盖中文字体处理、表格优化、批量进度监控等实用技巧,助力高效办公自动化。
775 0
|
4月前
|
安全 Linux 网络安全
Python极速搭建局域网文件共享服务器:一行命令实现HTTPS安全传输
本文介绍如何利用Python的http.server模块,通过一行命令快速搭建支持HTTPS的安全文件下载服务器,无需第三方工具,3分钟部署,保障局域网文件共享的隐私与安全。
845 0

推荐镜像

更多