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实现2048小游戏
Mar 30 Python
解决python3 urllib 链接中有中文的问题
Jul 16 Python
pyhanlp安装介绍和简单应用
Feb 22 Python
python sklearn库实现简单逻辑回归的实例代码
Jul 01 Python
PyCharm永久激活方式(推荐)
Sep 22 Python
Python实现疫情通定时自动填写功能(附代码)
May 27 Python
Keras load_model 导入错误的解决方式
Jun 09 Python
使用OpenCV对车道进行实时检测的实现示例代码
Jun 19 Python
Python logging模块异步线程写日志实现过程解析
Jun 30 Python
Python装饰器结合递归原理解析
Jul 02 Python
套娃式文件夹如何通过Python批量处理
Aug 23 Python
Python进阶学习之带你探寻Python类的鼻祖-元类
May 08 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 array操作10个小技巧分享
2011/06/23 PHP
不支持fsockopen但支持culr环境下下ucenter与modoer通讯问题
2011/08/12 PHP
解析php中curl_multi的应用
2013/07/17 PHP
去掉destoon资讯内容页keywords关键字自带的文章标题的方法
2014/08/21 PHP
PHP获取当前所在目录位置的方法
2014/11/26 PHP
PHP中把有符号整型转换为无符号整型方法
2015/05/27 PHP
Symfony2中被遗弃的getRequest()方法分析
2016/03/17 PHP
解读PHP中上传文件的处理问题
2016/05/29 PHP
浅谈PHP面向对象之访问者模式+组合模式
2017/05/22 PHP
深入理解 PHP7 中全新的 zval 容器和引用计数机制
2018/10/15 PHP
Laravel Eloquent分表方法并使用模型关联的实现
2019/11/25 PHP
javascript 三种方法实现获得和设置以及移除元素属性
2013/03/20 Javascript
解析js如何获取当前url中的参数值并复制给input
2013/06/23 Javascript
JQuery选择器、过滤器大整理
2015/05/26 Javascript
JS动态添加选项案例分析
2016/10/17 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
2017/02/20 Javascript
分享Bootstrap简单表格、表单、登录页面
2017/08/04 Javascript
Bootstrap Tooltip显示换行和左对齐的解决方案
2017/10/11 Javascript
vue2.0s中eventBus实现兄弟组件通信的示例代码
2017/10/25 Javascript
vue-cli中的babel配置文件.babelrc实例详解
2018/02/22 Javascript
mock.js实现模拟生成假数据功能示例
2019/01/15 Javascript
JavaScript装饰者模式原理与用法实例详解
2020/03/09 Javascript
rabbitmq(中间消息代理)在python中的使用详解
2017/12/14 Python
python实现壁纸批量下载代码实例
2018/01/25 Python
详解TensorFlow在windows上安装与简单示例
2018/03/05 Python
Python+Pandas 获取数据库并加入DataFrame的实例
2018/07/25 Python
详解python selenium 爬取网易云音乐歌单名
2019/03/28 Python
numpy数组之存取文件的实现示例
2019/05/24 Python
Django生成PDF文档显示在网页上以及解决PDF中文显示乱码的问题
2019/07/04 Python
如何用Python破解wifi密码过程详解
2019/07/12 Python
Django3中的自定义用户模型实例详解
2020/08/23 Python
HTML5页面嵌入小程序没有返回按钮及返回页面空白的问题
2020/05/28 HTML / CSS
仓库文员岗位职责
2014/04/06 职场文书
一分钟演讲稿
2014/04/30 职场文书
大学生党校培训心得体会
2014/09/11 职场文书
详解JSON.parse和JSON.stringify用法
2022/02/18 Javascript