9行Python3代码实现批量提取PDF文件的指定内容
作者:Carl_奕然 发布时间:2023-02-12 03:22:41
1、引言
小丝:鱼哥, 你有没有什么办法,提取PDF文档的内容。
小鱼:这个还问我??
小丝:哎呀,这个不是被难住了嘛 。
小鱼:有啥难得?提示你一下,
小丝:嗯,可以可以。
小鱼:去我的博文找,没记错的话,有两种方法提取pdf的文字。
小丝:好嘞, 我这就去…找找…
小丝:鱼哥,鱼哥~
小鱼:怎么样,你的这个需求,解决了吧。
小丝:没呢,我想批量提取指定PDF文档的内容…
小鱼:批…量…
小丝:对啊,是批量,
小鱼:这…还挺…
小丝:挺费劲吗?
小鱼:挺好的 ,不费劲, 一口气,上7楼…
小丝:打住… 说正事! !
小鱼:好嘞…
想到提取PDF文件的内容,我们第一反应就是pypdf,
因为pypdf这个库我在很多篇文章都介绍过, 还蛮好用的。
但是,今天,我们不使用pypdf,而是使用另一个库,即:pdfminer。
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
安装完成:
因为我们需要用到 pdfminer的high_level 方法,所以
这里必须要在安装pdfminer.six模块,否则会报错:
安装
pip install pdfminer.six
安装完成:
其它安装方式,直接看这两篇:
《Python3,选择Python自动安装第三方库,从此跟pip说拜拜!!》
《Python3:我低调的只用一行代码,就导入Python所有库!》
2.3 实例
安装完成,我们就来写上代码,
我们先来捋顺一下思路,主要分3步:
1、遍历pdf文件
注:如果文件夹的文件多个,需要单独提取目标pdf文件,否则都会轮巡匹配,费事费力费资源;
2、提取pdf文档内容
3、根据正则匹配,提取需要的文档信息
我们就根据这个思路,来提取"企业基本情况",代码如下:
代码示例
# -*- coding:utf-8 -*-
# @Time : 2022-11-30
# @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文件
运行结果
3、总结
看到这里,今天的分享,差不多就该结束了。
解析PDF是一件非常耗时和耗内存的工作,因此,pdfminer使用一种称作Lazy Parsing的策略,减少内耗…
小丝:怪不得, 提到批量提取pdf的文档内容, 你会犹豫了…
小鱼:对啊,因为我们的的测试文档内容很少,所以对内存的消耗相对来说没那么验证,当PDF文档的内容很多时, 就不得不使用pdfminer了。
来源:https://blog.csdn.net/wuyoudeyuer/article/details/128111719
猜你喜欢
- Create PROCEDURE Batch_Delete @TableName nvarchar(100), --表名 @FieldNam
- python部分#!/usr/bin/env Python# coding=utf-8from ctypes import *from Py
- 本文实例讲述了Python验证码识别的方法。分享给大家供大家参考。具体实现方法如下:#encoding=utf-8import Image,
- 线程实现Python中线程有两种方式:函数或者用类来包装线程对象。threading模块中包含了丰富的多线程支持功能:threading.c
- 原文: gradio.app/interface-s…1.全局状态例子来解释import gradio as grsc
- 环境: Python3 + windows。开发工具:Anaconda + Jupyter / VS Code。学习效果:1.认识爬虫 /
- 在这里我们介绍两个拼接数组的方法:np.vstack():在竖直方向上堆叠np.hstack():在水平方向上平铺import numpy
- 升级目前php最新版虽然是php5.5,但出于各种考虑,还是先升到php5.4比较靠谱。原php使用的是php5.2.10,已经运行了4~5
- 介绍go1.5+版本提供编译好的安装包,我们只需要解压到相应的目录,并添加一些环境变量的配置即可。Go语言的安装步骤
- 本文实例讲述了Python实现破解12306图片验证码的方法。分享给大家供大家参考,具体如下:不知从何时起,12306的登录验证码竟然变成了
- 前言:我们常常想使用数组的方法,比如forEach,filter,又或者some等等来处理非数组的数据类型,那么在这些场景下,我们就需要将非
- 安装了python3之后,会有pip31. 使用pip install XXX新安装的库会放在这个目录下面python2.7/site-pa
- 该语句的作用是:启用或禁用错误处理程序。一般用法如下:On Error Resume NextOn Error GoTo 0如果在您的代码中
- 404页面对于站长来说应该并不陌生,其作用无碍乎二点:提高用户体验和增强对搜索引擎的友好性。去年在跟几个朋友在聊天的时候,跟我说404页面不
- 本文实例讲述了Python网络编程之TCP套接字简单用法。分享给大家供大家参考,具体如下:上学期学的计算机网络,因为之前还未学习python
- 目录一、索引类型1.B+树2.MyISAM和InnoDB的B+树索引实现方式的区别(聚簇索引和非聚簇索引)?3.非聚簇索引4.聚簇索引的优缺
- 1.if ...else ...判断进行断言from time import *from selenium import webdriver
- batch的lstm# 导入相应的包import torchimport torch.nn as nnimport torch.nn.fun
- 查看逻辑读前10的SQL:set linesize 300;set pagesize 300;set long 50000;SELECT *
- Python注释python中单行注释采用 # 开头。python 中多行注释使用三个单引号(''')或三个双引号(