Python 3.6 中使用pdfminer解析pdf文件的实现


Posted in Python onSeptember 25, 2019

所使用python环境为最新的3.6版本

一、安装pdfminer模块

安装anaconda后,直接可以通过pip安装

pip install pdfminer3k

Python 3.6 中使用pdfminer解析pdf文件的实现 

如上图所示安装成功。

二、在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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python 切片和range()用法说明
Mar 24 Python
Python程序设计入门(2)变量类型简介
Jun 16 Python
Python多线程编程简单介绍
Apr 13 Python
python spyder中读取txt为图片的方法
Apr 27 Python
django请求返回不同的类型图片json,xml,html的实例
May 22 Python
tensorflow 恢复指定层与不同层指定不同学习率的方法
Jul 26 Python
用Python解决x的n次方问题
Feb 08 Python
Python使用dict.fromkeys()快速生成一个字典示例
Apr 24 Python
Python 程序报错崩溃后如何倒回到崩溃的位置(推荐)
Jun 23 Python
python实现取余操作的简单实例
Aug 16 Python
Python 操作SQLite数据库的示例
Oct 16 Python
python实现计算图形面积
Feb 22 Python
Python实现串口通信(pyserial)过程解析
Sep 25 #Python
Python根据服务获取端口号的方法
Sep 25 #Python
Python提取PDF内容的方法(文本、图像、线条等)
Sep 25 #Python
python使用 request 发送表单数据操作示例
Sep 25 #Python
Python实现PyPDF2处理PDF文件的方法示例
Sep 25 #Python
python mqtt 客户端的实现代码实例
Sep 25 #Python
python实现的登录与提交表单数据功能示例
Sep 25 #Python
You might like
PHP+jquery实时显示网站在线人数的方法
2015/01/04 PHP
php自定义函数实现JS的escape的方法示例
2016/07/07 PHP
PHP正则匹配操作简单示例【preg_match_all应用】
2017/07/10 PHP
js异或加解密效果代码
2008/06/25 Javascript
jQuery 使用手册(四)
2009/09/23 Javascript
jquery利用event.which方法获取键盘输入值的代码
2011/10/09 Javascript
jQuery+ajax中getJSON() 用法实例
2014/12/22 Javascript
javascript实现ecshop搜索框键盘上下键切换控制
2015/03/18 Javascript
javascript元素动态创建实现方法
2015/05/13 Javascript
解读Bootstrap v4 sass设计
2016/05/29 Javascript
js实现不提示直接关闭网页窗口
2017/03/30 Javascript
微信小程序实现动态设置页面标题的方法【附源码下载】
2017/11/29 Javascript
微信小程序之判断页面滚动方向的示例代码
2018/08/30 Javascript
小程序两种滚动公告栏的实现方法
2019/09/17 Javascript
js 数据类型判断的方法
2020/12/03 Javascript
[44:50]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第二局
2016/02/26 DOTA
Python Web开发模板引擎优缺点总结
2014/05/06 Python
Python实现XML文件解析的示例代码
2018/02/05 Python
python next()和iter()函数原理解析
2020/02/07 Python
基于Numba提高python运行效率过程解析
2020/03/02 Python
Python3 socket即时通讯脚本实现代码实例(threading多线程)
2020/06/01 Python
CSS3 简写animation
2012/05/10 HTML / CSS
前端面试必备之html5的新特性
2017/09/05 HTML / CSS
HTML5学习笔记之html5与传统html区别
2016/01/06 HTML / CSS
定制别致的瑜伽垫:Sugarmat
2019/06/21 全球购物
eBay比利时购物网站:eBay.be
2019/08/09 全球购物
Ruby如何定义一个类
2012/10/08 面试题
小溪流的歌教学反思
2014/02/13 职场文书
会计专业导师推荐信
2014/03/08 职场文书
团委书记的竞聘演讲稿
2014/04/24 职场文书
2014法院干警廉洁警示教育思想汇报
2014/09/13 职场文书
小学中等生评语
2014/12/29 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
基督教追悼会答谢词
2015/09/29 职场文书
剧场版《转生恶役只好拔除破灭旗标》公开最新视觉图 2023年上映
2022/04/02 日漫
最新动漫情报:2022年7月新番定档超过30部, OVERLORD骨王第四季也在其中噢
2022/05/04 日漫