Извлечение текста из файла PDF с помощью PDFMiner в python?
Python Version 2.7
Я ищу документацию или примеры того, как извлечь текст из PDF файла, используя PDFMiner с Python.
Похоже, что PDFMiner обновил свой API, и все соответствующие примеры, которые я нашел, содержат устаревший код (классы и методы были изменены). Библиотеки, которые я нашел, облегчают задачу извлечения текста из PDF файла, используют старый синтаксис PDFMiner, поэтому я не уверен, как это сделать.
Как бы то ни было, я просто смотрю на исходный код, чтобы понять, могу ли я это понять.
Ответы
Ответ 1
Вот рабочий пример извлечения текста из файла PDF с использованием текущей версии PDFMiner (сентябрь 2016 г.)
from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter
from pdfminer.converter import TextConverter
from pdfminer.layout import LAParams
from pdfminer.pdfpage import PDFPage
from io import StringIO
def convert_pdf_to_txt(path):
rsrcmgr = PDFResourceManager()
retstr = StringIO()
codec = 'utf-8'
laparams = LAParams()
device = TextConverter(rsrcmgr, retstr, codec=codec, laparams=laparams)
fp = open(path, 'rb')
interpreter = PDFPageInterpreter(rsrcmgr, device)
password = ""
maxpages = 0
caching = True
pagenos=set()
for page in PDFPage.get_pages(fp, pagenos, maxpages=maxpages, password=password,caching=caching, check_extractable=True):
interpreter.process_page(page)
text = retstr.getvalue()
fp.close()
device.close()
retstr.close()
return text
Структура PDFMiner недавно изменилась, поэтому это должно работать для извлечения текста из файлов PDF.
Изменить: по состоянию на 7 июня 2018 года все еще работает. Проверено в Python версии 3.x
Изменение: Решение работает с Python 3.7 3 октября 2019 года. Я использовал библиотеку Python pdfminer.six
, выпущенную в ноябре 2018 года.
Ответ 2
потрясающий ответ от DuckPuncher, для Python3 убедитесь, что вы установили pdfminer2 и выполните:
import io
from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter
from pdfminer.converter import TextConverter
from pdfminer.layout import LAParams
from pdfminer.pdfpage import PDFPage
def convert_pdf_to_txt(path):
rsrcmgr = PDFResourceManager()
retstr = io.StringIO()
codec = 'utf-8'
laparams = LAParams()
device = TextConverter(rsrcmgr, retstr, codec=codec, laparams=laparams)
fp = open(path, 'rb')
interpreter = PDFPageInterpreter(rsrcmgr, device)
password = ""
maxpages = 0
caching = True
pagenos = set()
for page in PDFPage.get_pages(fp, pagenos, maxpages=maxpages,
password=password,
caching=caching,
check_extractable=True):
interpreter.process_page(page)
text = retstr.getvalue()
fp.close()
device.close()
retstr.close()
return text