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调用java的Webservice示例
Mar 10 Python
更改Ubuntu默认python版本的两种方法python-> Anaconda
Dec 18 Python
Python实现k-means算法
Feb 23 Python
Python 输入一个数字判断成绩分数等级的方法
Nov 15 Python
CentOS7安装Python3的教程详解
Apr 10 Python
scrapy-redis源码分析之发送POST请求详解
May 15 Python
Python 分享10个PyCharm技巧
Jul 13 Python
python RC4加密操作示例【测试可用】
Sep 26 Python
python装饰器练习题及答案
Nov 01 Python
python 爬取马蜂窝景点翻页文字评论的实现
Jan 20 Python
python中urllib包的网络请求教程
Apr 19 Python
python解析照片拍摄时间进行图片整理
Jul 23 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中数组合并的两种方法及区别介绍
2012/09/14 PHP
解析PHP跨站刷票的实现代码
2013/06/18 PHP
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)
2014/11/08 PHP
PHP中把数据库查询结果输出为json格式简单实例
2015/04/09 PHP
CI框架(CodeIgniter)操作redis的方法详解
2018/01/25 PHP
TP5框架页面跳转样式操作示例
2020/04/05 PHP
JavaScript 面向对象之命名空间
2010/05/04 Javascript
jQuery实现图片局部放大镜效果
2016/03/17 Javascript
java中String类型变量的赋值问题介绍
2016/03/23 Javascript
JavaScript 弹出子窗体并返回结果到父窗体的实现代码
2016/05/28 Javascript
JS修改地址栏参数实例代码
2016/06/14 Javascript
利用iscroll4实现轮播图效果实例代码
2017/01/11 Javascript
jQuery选择器之子元素过滤选择器
2017/09/28 jQuery
JavaScript如何获取到导航条中HTTP信息
2017/10/10 Javascript
jQuery轻量级表单模型验证插件
2018/10/15 jQuery
VUE+Element UI实现简单的表格行内编辑效果的示例的代码
2018/10/31 Javascript
微信小程序自定义可滑动日历界面
2018/12/28 Javascript
Vue指令v-for遍历输出JavaScript数组及json对象的常见方式小结
2019/02/11 Javascript
element-ui组件中input等的change事件中传递自定义参数
2019/05/22 Javascript
Vue在chrome44偶现点击子元素事件无法冒泡的解决方法
2019/12/15 Javascript
vue 使用lodash实现对象数组深拷贝操作
2020/09/10 Javascript
Python编码时应该注意的几个情况
2013/03/04 Python
python连接mysql并提交mysql事务示例
2014/03/05 Python
python开发之字符串string操作方法实例详解
2015/11/12 Python
requests和lxml实现爬虫的方法
2017/06/11 Python
Python抓取框架Scrapy爬虫入门:页面提取
2017/12/01 Python
python 通过logging写入日志到文件和控制台的实例
2018/04/28 Python
用于ETL的Python数据转换工具详解
2020/07/21 Python
python调用百度AI接口实现人流量统计
2021/02/03 Python
阿迪达斯香港官网:adidas香港
2019/11/09 全球购物
俄罗斯家居用品购物网站:Евродом
2020/11/21 全球购物
大学班级计划书
2014/04/29 职场文书
四风问题个人对照检查剖析材料
2014/09/27 职场文书
刑事附带民事诉讼答辩状
2015/05/22 职场文书
大国崛起英国观后感
2015/06/02 职场文书
小学运动会宣传稿
2015/07/23 职场文书