首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用Python从PDF中提取文本

用Python从PDF中提取文本
EN

Stack Overflow用户
提问于 2017-03-22 21:16:50
回答 3查看 7.8K关注 0票数 1

我有一份PDF格式的引文:

https://www.pdf-archive.com/2017/03/22/test/

我可以使用以下代码在python中提取文本:

代码语言:javascript
运行
复制
import PyPDF2

pdfFileObj = open('example.pdf','rb') 
pdfReader = PyPDF2.PdfFileReader(pdfFileObj)
pageObj = pdfReader.getPage(0)         
print (pageObj.extractText())

这会将所有引号作为一个段落返回。是否有可能通过水平分隔符将pdf“拆分”并以这种方式将其拆分为引号?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-03-22 21:35:21

如果您只想从pdf文本中提取引号,可以使用regex查找所有引号。

代码语言:javascript
运行
复制
import PyPDF2
import re
pdfFileObj = open('test.pdf','rb') 
pdfReader = PyPDF2.PdfFileReader(pdfFileObj)
pageObj = pdfReader.getPage(0)         
text = str(pageObj.extractText())

quotes = re.findall(r'"[^"]*"',text)
for quote in quotes:
    print quote
    print 

或者只是

代码语言:javascript
运行
复制
quotes = re.findall(r'"[^"]*"',text)
print quotes
票数 1
EN

Stack Overflow用户

发布于 2017-03-22 21:26:38

我找不到用水平分隔符来分割它的方法,但我设法以另一种方式实现了它:

代码语言:javascript
运行
复制
import PyPDF2

quotes = []

pdfFileObj = open('test.pdf','rb') 
pdfReader = PyPDF2.PdfFileReader(pdfFileObj)
pageObj = pdfReader.getPage(0)         
for x in (pageObj.extractText()).split('"\n'): print x+"\n"*5
票数 0
EN

Stack Overflow用户

发布于 2019-07-10 08:43:40

代码语言:javascript
运行
复制
import pdfplumber

pdf = pdfplumber.open(file_path)

p0 = pdf.pages[0]

text = p0.extract_text()

text
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42962811

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档