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创建和使用字典实例详解
Nov 01 Python
python在指定目录下查找gif文件的方法
May 04 Python
Django实现图片文字同时提交的方法
May 26 Python
python数组复制拷贝的实现方法
Jun 09 Python
Python实现简单网页图片抓取完整代码实例
Dec 15 Python
解决python nohup linux 后台运行输出的问题
May 11 Python
python3操作注册表的方法(Url protocol)
Feb 05 Python
python实现将两个文件夹合并至另一个文件夹(制作数据集)
Apr 03 Python
使用Python将语音转换为文本的方法
Aug 10 Python
Python SMTP发送电子邮件的示例
Sep 23 Python
python爬虫 requests-html的使用
Nov 30 Python
解决Pyinstaller打包软件失败的一个坑
Mar 04 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
php快速url重写更新版[需php 5.30以上]
2010/04/25 PHP
php过滤表单提交的html等危险代码
2014/11/03 PHP
php正则表达式获取内容所有链接
2015/07/24 PHP
yum命令安装php7和相关扩展
2016/07/04 PHP
LaravelS通过Swoole加速Laravel/Lumen详解
2018/03/02 PHP
PHP实现普通hash分布式算法简单示例
2018/08/06 PHP
php 自定义函数实现将数据 以excel 表格形式导出示例
2019/11/13 PHP
JavaScript 学习小结(适合新手参考)
2009/07/30 Javascript
JS实现鼠标点击展开或隐藏表格行的方法
2015/03/03 Javascript
jQuery实现转动随机数抽奖效果的方法
2015/05/21 Javascript
js实现仿MSN带关闭功能的右下角弹窗代码
2015/09/04 Javascript
jquery实现的简单二级菜单效果代码
2015/09/22 Javascript
轻松掌握JavaScript享元模式
2016/08/27 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
Bootstrap CDN和本地化环境搭建
2016/10/26 Javascript
jquery dataTable 获取某行数据
2017/05/05 jQuery
jQuery UI Draggable + Sortable 结合使用(实例讲解)
2017/09/07 jQuery
深入理解js A*寻路算法原理与具体实现过程
2018/12/13 Javascript
vue页面加载时的进度条功能(实例代码)
2020/01/13 Javascript
JavaScript数组排序的六种常见算法总结
2020/08/18 Javascript
[01:11:08]Winstrike vs NB 2018国际邀请赛淘汰赛BO1 8.21
2018/08/22 DOTA
用Python程序抓取网页的HTML信息的一个小实例
2015/05/02 Python
约瑟夫问题的Python和C++求解方法
2015/08/20 Python
Python六大开源框架对比
2015/10/19 Python
python3读取csv和xlsx文件的实例
2018/06/22 Python
删除DataFrame中值全为NaN或者包含有NaN的列或行方法
2018/11/06 Python
详解如何用python实现一个简单下载器的服务端和客户端
2019/10/28 Python
ubuntu 安装pyqt5和卸载pyQt5的方法
2020/03/24 Python
CSS3模块的目前的状况分析
2010/02/24 HTML / CSS
Javascript 高级手势使用介绍
2013/04/21 HTML / CSS
美国全球旅游运营商:Pacific Holidays
2018/06/18 全球购物
建筑工程材料员岗位职责
2015/04/11 职场文书
初中英语教学随笔
2015/08/15 职场文书
2019年聘任书的写作格式及范文!
2019/07/03 职场文书