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 相关文章推荐
pycharm 使用心得(二)设置字体大小
Jun 05 Python
Python中使用copy模块实现列表(list)拷贝
Apr 14 Python
python中安装Scrapy模块依赖包汇总
Jul 02 Python
python django 增删改查操作 数据库Mysql
Jul 27 Python
python编程使用selenium模拟登陆淘宝实例代码
Jan 25 Python
Python使用pyshp库读取shapefile信息的方法
Dec 29 Python
python多线程http压力测试脚本
Jun 25 Python
Python简易版停车管理系统
Aug 12 Python
Python 共享变量加锁、释放详解
Aug 28 Python
python实现二分类的卡方分箱示例
Nov 22 Python
PyCharm第一次安装及使用教程
Jan 08 Python
python字典的值可以修改吗
Jun 29 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
用ODBC的分页显示
2006/10/09 PHP
php数组键值用法实例分析
2015/02/27 PHP
在Yii2中使用Pjax导致Yii2内联脚本载入失败的原因分析
2016/03/06 PHP
PHP PDOStatement::setAttribute讲解
2019/02/01 PHP
jQuery Div中加载其他页面的实现代码
2009/02/27 Javascript
jQuery弹性滑动导航菜单实现思路及代码
2013/05/02 Javascript
js弹出div并显示遮罩层
2014/02/12 Javascript
nodejs实现黑名单中间件设计
2014/06/17 NodeJs
jQuery插件datatables使用教程
2016/04/21 Javascript
angular.js 路由及页面传参示例
2017/02/24 Javascript
jQuery设计思想
2017/03/07 Javascript
jQuery滑动到底部加载下一页数据的实例代码
2017/05/22 jQuery
nodejs操作mysql实现增删改查的实例
2017/05/28 NodeJs
详解如何用webpack打包一个网站应用项目
2017/07/12 Javascript
vue axios登录请求拦截器
2018/04/02 Javascript
WebGL学习教程之Three.js学习笔记(第一篇)
2019/04/25 Javascript
vue下使用nginx刷新页面404的问题解决
2019/08/02 Javascript
Node.js API详解之 module模块用法实例分析
2020/05/13 Javascript
Electron+vue从零开始打造一个本地播放器的方法示例
2020/10/27 Javascript
Python简单调用MySQL存储过程并获得返回值的方法
2015/07/20 Python
简单掌握Python中glob模块查找文件路径的用法
2016/07/05 Python
Python处理CSV与List的转换方法
2018/04/19 Python
Django打印出在数据库中执行的语句问题
2019/07/25 Python
python如何建立全零数组
2020/07/19 Python
Python为何不支持switch语句原理详解
2020/10/21 Python
清除canvas画布内容(点擦除+线擦除)
2020/08/12 HTML / CSS
澳大利亚领先的睡衣品牌:Peter Alexander
2016/08/16 全球购物
全球领先的各类汽车配件零售商:Advance Auto Parts
2016/08/26 全球购物
卡骆驰英国官网:Crocs英国
2019/08/22 全球购物
我的五年职业生涯规划
2014/01/23 职场文书
中国好声音广告词
2014/03/18 职场文书
征用土地赔偿协议书
2014/09/26 职场文书
学校党委副书记个人对照检查材料思想汇报
2014/09/28 职场文书
小学生校园广播稿
2014/09/28 职场文书
浅谈Python响应式类库RxPy
2021/06/14 Python
AndroidStudio图片压缩工具ImgCompressPlugin使用实例
2022/08/05 Java/Android