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 相关文章推荐
在Linux下使用Python的matplotlib绘制数据图的教程
Jun 11 Python
使用Python的Scrapy框架十分钟爬取美女图
Dec 26 Python
JPype实现在python中调用JAVA的实例
Jul 19 Python
python实现TF-IDF算法解析
Jan 02 Python
对Django 中request.get和request.post的区别详解
Aug 12 Python
Spring实战之使用util:命名空间简化配置操作示例
Dec 09 Python
Python callable内置函数原理解析
Mar 05 Python
django rest framework serializers序列化实例
May 13 Python
python能开发游戏吗
Jun 11 Python
Python如何解除一个装饰器
Aug 07 Python
Python的信号库Blinker用法详解
Dec 31 Python
python基础之爬虫入门
May 10 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脚本数据库功能详解(下)
2006/10/09 PHP
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
2013/06/29 PHP
PHP实现获取客户端IP并获取IP信息
2015/03/17 PHP
jquery HotKeys轻松搞定键盘事件代码
2008/08/30 Javascript
IE6,IE7,IE8下使用Javascript记录光标选中范围(已补全)
2011/08/28 Javascript
js动态给table添加/删除tr的方法
2013/08/02 Javascript
浏览器图片选择预览、旋转、批量上传的JS代码实现
2013/12/04 Javascript
js实现鼠标悬停图片上时滚动文字说明的方法
2015/02/17 Javascript
JavaScript判断按钮被点击的方法
2015/12/13 Javascript
让编辑器支持word复制黏贴、截屏的js代码
2016/10/17 Javascript
JS实现图片上传预览功能
2016/11/21 Javascript
微信小程序 页面跳转传值实现代码
2017/07/27 Javascript
vue.js 图片上传并预览及图片更换功能的实现代码
2018/08/27 Javascript
详解vue组件中使用路由方法
2019/02/12 Javascript
浅谈Webpack4 Tree Shaking 终极优化指南
2019/11/18 Javascript
Python 自动化表单提交实例代码
2017/06/08 Python
Python实现翻转数组功能示例
2018/01/12 Python
django用户登录和注销的实现方法
2018/07/16 Python
win10下安装Anaconda的教程(python环境+jupyter_notebook)
2019/10/23 Python
Python hashlib模块加密过程解析
2019/11/05 Python
基于python实现蓝牙通信代码实例
2019/11/19 Python
python else语句在循环中的运用详解
2020/07/06 Python
HEMA英国:荷兰原创设计
2018/08/28 全球购物
linux面试题参考答案(3)
2012/09/13 面试题
软件测试工程师结构化面试题库
2016/11/23 面试题
网络信息管理员岗位职责
2014/01/05 职场文书
老同学聚会感言
2014/02/23 职场文书
餐饮业员工工作决心书
2014/03/11 职场文书
行政专员岗位职责范本
2014/08/26 职场文书
教师学习八项规定六项禁令思想汇报
2014/09/27 职场文书
四风个人对照检查材料思想汇报(办公室通用版)
2014/10/07 职场文书
商务英语求职信范文
2015/03/19 职场文书
教师节简报
2015/07/20 职场文书
Redis性能监控的实现
2021/07/09 Redis
如何利用Python实现n*n螺旋矩阵
2022/01/18 Python
美国运营商 T-Mobile 以 117.83Mb/s 的速度排第一位
2022/04/21 数码科技