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的Django框架中的templates设置
May 11 Python
Python 功能和特点(新手必学)
Dec 30 Python
python 编程之twisted详解及简单实例
Jan 28 Python
python中如何使用正则表达式的集合字符示例
Oct 09 Python
使用实现XlsxWriter创建Excel文件并编辑
May 04 Python
微信公众号token验证失败解决方案
Jul 22 Python
python3安装crypto出错及解决方法
Jul 30 Python
Python configparser模块配置文件过程解析
Mar 03 Python
利用python在excel中画图的实现方法
Mar 17 Python
python3检查字典传入函数键是否齐全的实例
Jun 05 Python
基于Python下载网络图片方法汇总代码实例
Jun 24 Python
Django中日期时间型字段进行年月日时分秒分组统计
Nov 27 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
关于js和php对url编码的处理方法
2014/03/04 PHP
浅析php创建者模式
2014/11/25 PHP
PIGCMS 如何关闭聊天机器人
2015/02/12 PHP
Laravel执行migrate命令提示:No such file or directory的解决方法
2016/03/16 PHP
symfony2.4的twig中date用法分析
2016/03/18 PHP
PHP中递归的实现实例详解
2017/11/14 PHP
浅谈laravel数据库查询返回的数据形式
2019/10/21 PHP
JavaScript使用setTimeout实现延迟弹出警告框的方法
2015/04/07 Javascript
javascript时间排序算法实现活动秒杀倒计时效果
2021/01/28 Javascript
jQuery实现图片滑动效果
2017/03/08 Javascript
Axios学习笔记之使用方法教程
2017/07/21 Javascript
webpack开发环境和生产环境的深入理解
2018/11/08 Javascript
JS中数据结构之栈
2019/01/01 Javascript
基于three.js实现的3D粒子动效实例代码
2019/04/09 Javascript
Mac OS X10.9安装的Python2.7升级Python3.3步骤详解
2013/12/04 Python
Python中的面向对象编程详解(上)
2015/04/13 Python
连接Python程序与MySQL的教程
2015/04/29 Python
利用python编写一个图片主色转换的脚本
2017/12/07 Python
python回调函数中使用多线程的方法
2017/12/25 Python
python Tkinter版学生管理系统
2019/02/20 Python
500行代码使用python写个微信小游戏飞机大战游戏
2019/10/16 Python
纯css3实现照片墙效果
2014/12/26 HTML / CSS
naturalizer加拿大官网:美国娜然女鞋
2017/04/04 全球购物
味多美官网:蛋糕订购,100%使用天然奶油
2017/11/10 全球购物
Linux管理员面试题 Linux admin interview questions
2014/11/01 面试题
如何写出好的Java代码
2014/04/25 面试题
一套英文Java笔试题面试题
2016/04/21 面试题
校园网站的创业计划书范文
2013/12/30 职场文书
先进德育工作者事迹材料
2014/01/24 职场文书
2014年学生会干事工作总结
2014/11/07 职场文书
教师继续教育反思周记
2015/06/25 职场文书
2016圣诞节贺卡寄语
2015/12/07 职场文书
Spring Boot 启动、停止、重启、状态脚本
2021/06/26 Java/Android
javascript拖曳互换div的位置实现示例
2021/06/28 Javascript
讨论nginx location 顺序问题
2022/05/30 Servers