Python 3.6 中使用pdfminer解析pdf文件的实现
作者:W-大泡泡 时间:2023-09-02 08:34:08
所使用python环境为最新的3.6版本
一、安装pdfminer模块
安装anaconda后,直接可以通过pip安装
pip install pdfminer3k
如上图所示安装成功。
二、在IDE中进行编码
#!/usr/bin/env python
# encoding: utf-8
"""
@author: wugang
@software: PyCharm
@file: prase_pdf.py
@time: 2017/3/3 0003 11:16
"""
import sys
import importlib
importlib.reload(sys)
from pdfminer.pdfparser import PDFParser,PDFDocument
from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter
from pdfminer.converter import PDFPageAggregator
from pdfminer.layout import LTTextBoxHorizontal,LAParams
from pdfminer.pdfinterp import PDFTextExtractionNotAllowed
'''
解析pdf 文本,保存到txt文件中
'''
path = r'../../data/pdf/阿里巴巴Java开发规范手册.pdf'
def parse():
fp = open(path, 'rb') # 以二进制读模式打开
#用文件对象来创建一个pdf文档分析器
praser = PDFParser(fp)
# 创建一个PDF文档
doc = PDFDocument()
# 连接分析器 与文档对象
praser.set_document(doc)
doc.set_parser(praser)
# 提供初始化密码
# 如果没有密码 就创建一个空的字符串
doc.initialize()
# 检测文档是否提供txt转换,不提供就忽略
if not doc.is_extractable:
raise PDFTextExtractionNotAllowed
else:
# 创建PDf 资源管理器 来管理共享资源
rsrcmgr = PDFResourceManager()
# 创建一个PDF设备对象
laparams = LAParams()
device = PDFPageAggregator(rsrcmgr, laparams=laparams)
# 创建一个PDF解释器对象
interpreter = PDFPageInterpreter(rsrcmgr, device)
# 循环遍历列表,每次处理一个page的内容
for page in doc.get_pages(): # doc.get_pages() 获取page列表
interpreter.process_page(page)
# 接受该页面的LTPage对象
layout = device.get_result()
# 这里layout是一个LTPage对象 里面存放着 这个page解析出的各种对象 一般包括LTTextBox, LTFigure, LTImage, LTTextBoxHorizontal 等等 想要获取文本就获得对象的text属性,
for x in layout:
if (isinstance(x, LTTextBoxHorizontal)):
with open(r'../../data/pdf/1.txt', 'a') as f:
results = x.get_text()
print(results)
f.write(results + '\n')
if __name__ == '__main__':
parse()
来源:https://blog.csdn.net/u011389474/article/details/60139786
标签:Python3.6,pdfminer,pdf
0
投稿
猜你喜欢
利用pyinstaller或virtualenv将python程序打包详解
2022-08-01 10:37:52
python 删除字符串中连续多个空格并保留一个的方法
2021-08-16 14:07:25
Go语言并发爬虫的具体实现
2024-02-22 10:35:31
Vue 3.x+axios跨域方案的踩坑指南
2024-05-09 09:21:15
Python使用JSON库解析JSON数据的方法
2021-09-24 13:35:10
python下如何查询CS反恐精英的服务器信息
2021-09-15 05:51:47
Tensorflow2.1实现文本中情感分类实现解析
2022-12-22 17:49:51
利用Python如何生成便签图片详解
2021-01-02 18:09:52
判断触发器正在处理的是插入,删除还是更新触发
2024-01-19 02:03:28
如何提高Request集合的使用效率?
2010-06-07 20:53:00
vue-seamless-scroll无缝滚动组件使用方法详解
2024-04-29 13:07:51
网页屏蔽鼠标左右键和键盘按键功能
2007-10-17 21:30:00
Python selenium根据class定位页面元素的方法
2021-04-03 08:17:39
MYSQL建立外键失败几种情况记录Can't create table不能创建表
2024-01-22 19:57:22
python2.7 安装pip的方法步骤(管用)
2022-02-11 06:28:43
python实现删除列表中某个元素的3种方法
2023-02-08 16:01:59
python重试装饰器的简单实现方法
2022-07-15 12:54:10
Golang 性能基准测试(benchmark)详解
2024-02-08 03:10:11
order by newid() 各种数据库随机查询的方法
2024-01-19 16:53:14
Dreamweaver MX技巧之超链接
2009-05-29 18:40:00