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 安装

安装


pip install pdfminer


安装完成

image.png


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

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


安装

pip install pdfminer.six


安装完成

image.png


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


2.3 实例

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

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


  • 1、遍历pdf文件

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

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

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


代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-12-10
# @Author : Carl_DJ
from pdfminer import high_level
import re,os
#pdf文件路径
#root:文件夹路径,dirs:文件夹下子目录名,files:文件夹下的文件
for root,dirs,files in os.walk('./data/'):
    #遍历pdf文件
    for f in files:
        file_name = os.path.join(root,f)
        if file_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知识。


目录
相关文章
|
9月前
|
Python
Python提取pdf中的表格数据(附实战案例)
Python提取pdf中的表格数据(附实战案例)
513 0
Python提取pdf中的表格数据(附实战案例)
|
10月前
|
Java Unix Linux
知识分享之Golang——读取pdf中纯文本内容
知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。 知识分享系列目前包含Java、Golang、Linux、Docker等等。
916 1
知识分享之Golang——读取pdf中纯文本内容
|
11月前
|
JSON Java BI
Java 解析pdf文档内容实战案例
Java 解析pdf文档内容实战案例
Java 解析pdf文档内容实战案例
|
11月前
|
IDE 开发工具 Python
python 读出pdf文件中的内容
python 读出pdf文件中的内容
50 0
|
JSON 自然语言处理 数据可视化
如何用Elasticsearch实现Word、PDF,TXT文件的全文内容检索?
如何用Elasticsearch实现Word、PDF,TXT文件的全文内容检索?
如何用Elasticsearch实现Word、PDF,TXT文件的全文内容检索?
|
人工智能 前端开发 Linux
Python编程:利用ImageMagick转换PDF为图片并识别提取图表
Python编程:利用ImageMagick转换PDF为图片并识别提取图表
130 0
|
机器学习/深度学习 人工智能 文字识别
【前沿技术RPA】 一文学会用UiPath实现PDF自动化——从 PDF 提取单个数据段
UiPath在传统的RPA(Robotic process automation)的基础上,增加了See(AI通过计算机视觉阅读用户的计算机屏幕)和Think(通过机器学习来发现平台能够为用户构建什么自动化流程)从而不断帮助用户自动化构建流程,而不仅仅是用户自主发现,自主构建。并且在构建的过程当中,做到了Low-code甚至是No-code的程度,让每一位员工都可以自主使用。
【前沿技术RPA】 一文学会用UiPath实现PDF自动化——从 PDF 提取单个数据段
|
数据安全/隐私保护 Python
python自动化系列之提取pdf文字和图片
python自动化系列之提取pdf文字和图片
575 0
python自动化系列之提取pdf文字和图片
|
SQL 分布式计算 数据可视化
PDF中数据的提取与处理
背景在当下的大数据时代中,各行各业都同时面临大数据所带来的数据规模大和数据来源繁多的机遇与挑战。如何更好的获取数据、处理数据和合并数据对于提高工作效率是至关重要的。 PDF是非常常见的数据来源,尤其见于公司的各种报告和报表中。
|
索引 Python
Python骚操作,提取pdf文件中的表格数据!
Python骚操作,提取pdf文件中的表格数据!
5816 0
相关产品
云迁移中心
相关实验场景
更多
推荐文章
更多