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实现二分查找算法实例
May 26 Python
Python语言实现机器学习的K-近邻算法
Jun 11 Python
基于python进行桶排序与基数排序的总结
May 29 Python
如何安装多版本python python2和python3共存以及pip共存
Sep 18 Python
selenium+python截图不成功的解决方法
Jan 30 Python
简单了解Django应用app及分布式路由
Jul 24 Python
使用Python生成200个激活码的实现方法
Nov 22 Python
np.random.seed() 的使用详解
Jan 14 Python
python等差数列求和公式前 100 项的和实例
Feb 25 Python
基于python检查矩阵计算结果
May 21 Python
python多线程semaphore实现线程数控制的示例
Aug 10 Python
Django-celery-beat动态添加周期性任务实现过程解析
Nov 26 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
第十二节 类的自动加载 [12]
2006/10/09 PHP
php array_map()数组函数使用说明
2011/07/12 PHP
PHP程序开发范例学习之表单 获取文本框的值
2011/08/08 PHP
迅速确定php多维数组的深度的方法
2014/01/07 PHP
PHP实现一维数组与二维数组去重功能示例
2018/05/24 PHP
JavaScript实用技巧(一)
2010/08/16 Javascript
JS中动态添加事件(绑定事件)的代码
2011/01/09 Javascript
Js数组的操作push,pop,shift,unshift等方法详细介绍
2012/12/28 Javascript
仿当当网淘宝网等主流电子商务网站商品分类导航菜单
2013/09/25 Javascript
jQuery插件ImageDrawer.js实现动态绘制图片动画(附源码下载)
2016/02/25 Javascript
canvas滤镜效果实现代码
2017/02/06 Javascript
基于jQuery实现简单人工智能聊天室
2017/02/10 Javascript
JS设置手机验证码60s等待实现代码
2017/06/14 Javascript
jQuery动态添加元素无法触发绑定事件的解决方法分析
2018/01/02 jQuery
vue 使用自定义指令实现表单校验的方法
2018/08/28 Javascript
Vue中使用Lodop插件实现打印功能的简单方法
2019/12/19 Javascript
Python 正则表达式(转义问题)
2014/12/15 Python
使用Python制作微信跳一跳辅助
2018/01/31 Python
python写入已存在的excel数据实例
2018/05/03 Python
python 多线程将大文件分开下载后在合并的实例
2018/11/09 Python
python 直接赋值和copy的区别详解
2019/08/07 Python
Python中关于logging模块的学习笔记
2020/06/03 Python
为什么说python更适合树莓派编程
2020/07/20 Python
PyQt实现计数器的方法示例
2021/01/18 Python
英国最大的奢侈珠宝和手表网站:C W Sellors
2017/02/10 全球购物
饿了么订餐官网:外卖、网上订餐
2019/06/28 全球购物
在职研究生自我鉴定
2013/10/16 职场文书
医学检验专业大学生求职信
2013/11/18 职场文书
竞争性谈判邀请书
2014/02/06 职场文书
职工运动会感言
2014/02/07 职场文书
世界遗产的导游词
2015/02/13 职场文书
汽车4S店销售经理岗位职责
2015/04/02 职场文书
2015年妇幼卫生工作总结
2015/05/23 职场文书
初中数学课堂教学反思
2016/02/17 职场文书
MySQL千万级数据表的优化实战记录
2021/08/04 MySQL
python缺失值填充方法示例代码
2022/12/24 Python