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类的动态修改的实例方法
Mar 24 Python
python利用插值法对折线进行平滑曲线处理
Dec 25 Python
Python爬取数据保存为Json格式的代码示例
Apr 09 Python
Gauss-Seidel迭代算法的Python实现详解
Jun 29 Python
Python实现12306火车票抢票系统
Jul 04 Python
Python学习笔记之字符串和字符串方法实例详解
Aug 22 Python
Python中Unittest框架的具体使用
Aug 27 Python
Python 可变类型和不可变类型及引用过程解析
Sep 27 Python
python3用urllib抓取贴吧邮箱和QQ实例
Mar 10 Python
python实现二分类和多分类的ROC曲线教程
Jun 15 Python
只用50行Python代码爬取网络美女高清图片
Jun 02 Python
python套接字socket通信
Apr 01 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在DOS命令行下却无法链接MySQL的技术笔记
2010/12/29 PHP
js基于qrcode.js生成二维码的方法【附demo插件源码下载】
2016/12/28 PHP
PHP观察者模式实例分析【对比JS观察者模式】
2019/05/22 PHP
PHP保留两位小数的几种方法
2019/07/24 PHP
PHP中Session ID的实现原理实例分析
2019/08/17 PHP
jQuery 页面载入进度条实现代码
2009/02/08 Javascript
JS使用ajax方法获取指定url的head信息中指定字段值的方法
2015/03/24 Javascript
Bootstrap树形控件使用方法详解
2016/01/27 Javascript
javascript弹出窗口中增加确定取消按钮
2016/06/24 Javascript
jquery Banner轮播选项卡
2016/12/26 Javascript
12条写出高质量JS代码的方法
2018/01/07 Javascript
详解ES6语法之可迭代协议和迭代器协议
2018/01/13 Javascript
关于Vue的路由权限管理的示例代码
2018/03/06 Javascript
基于webpack4搭建的react项目框架的方法
2018/06/30 Javascript
详解微信小程序中组件通讯
2018/10/30 Javascript
nuxt.js中间件实现拦截权限判断的方法
2018/11/21 Javascript
Python Socket编程入门教程
2014/07/11 Python
跟老齐学Python之深入变量和引用对象
2014/09/24 Python
Python实现的tab文件操作类分享
2014/11/20 Python
详解Python的Django框架中manage命令的使用与扩展
2016/04/11 Python
Python实现矩阵相乘的三种方法小结
2018/07/26 Python
浅谈django rest jwt vue 跨域问题
2018/10/26 Python
Python实现的对一个数进行因式分解操作示例
2019/06/27 Python
基于python实现自动化办公学习笔记(CSV、word、Excel、PPT)
2019/08/06 Python
centos7中安装python3.6.4的教程
2019/12/11 Python
在python3中实现查找数组中最接近与某值的元素操作
2020/02/29 Python
Python3 ID3决策树判断申请贷款是否成功的实现代码
2020/05/21 Python
Expedia韩国官网:亚洲发展最快的在线旅游门户网站
2018/02/26 全球购物
非功能性需求都包括哪些方面
2013/10/29 面试题
高中自我鉴定
2013/12/20 职场文书
银行职业规划书范文
2013/12/28 职场文书
旷课检讨书3000字
2014/02/04 职场文书
世博会口号
2014/06/20 职场文书
我的中国心演讲稿
2014/09/04 职场文书
2015年度绩效考核工作总结
2015/05/27 职场文书
一文搞懂php的垃圾回收机制
2021/06/18 PHP