基本信息
源码名称:python 解析pdf文件中的文字成字符串(pdfminer3k)
源码大小:7.25M
文件格式:.zip
开发语言:Python
更新时间:2018-03-23
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 3 元×
微信扫码支付:3 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
首先安装这个 pip install pdfminer3k
然后将 附件中 1-297.pdf文件 放到 D:/test 目录下
然后在 python 3.6 环境下 运行 ParserPdf.py文件,即可看到如下效果
#!/usr/bin/env python # encoding: utf-8 """ @author: guoliang @software: PyCharm @file: prase_pdf.py @time: 2018/1/25 """ import 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'D:\test\1-297.pdf' def parse(): contentText = "" 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'D:\test\1-297.txt', 'a',encoding='utf8') as f: results = x.get_text() # if r"摘 要" in results: # results.replace(r'摘 要', r'摘 要:') if r"企 业 管 理" in results : # or r"管 理 科 学" in results \ # or r"财 税 统 计" in results or r"地 质 矿 山" in results \ # or r"工 程 技 术" in results or r"建 筑 施 工" in results \ # or r"市 政 建 设" in results or r"法 律 园 地" in results \ # or r"社 科 论 坛" in results or r"实 用 科 技" in results \ # or r"信 息 技 术" in results or r"职 业 教 育" in results \ # or r"科 学 实 践" in results : print ("--------------------栏目:" results) count = 0 count = 1 if count==2 and len(results)<60: print("题目:" results) if results.startswith("要要要"): print("副标题:" results[3:]) elif count == 3 and len(results)<9: print("作者:" results) # contentText=contentText results if count == 4 and len(results) < 9: print("作者:" results) # if count == 5 and len(results) < 9: # print("单位:" results) if results.startswith("摘 要"): list=results.split('\n') str="" for i in list: if ("关键词") in i: break str=str i print("摘要:" str[4:]) print("关键词:" results.split('\n')[-2][4:]) if not results.startswith("摘 要") and len(results) >159: print("正文:" results) if r"参考文献" in results: print("参考文献:" results) f.write(results '\n') return contentText def contentParse(contentStr): list=contentStr.split(r'企 业 管 理') print (list) if __name__ == '__main__': contentStr=parse() # contentParse(contentStr)