PDFMiner 패키지를 사용하여 PDF를 텍스트로 변환할 수 있습니다.
예시
다음과 같은 방법으로 사용할 수 있습니다.
import sys
from cStringIO import StringIO
from pdfminer.pdfpage importPDFPage
from pdfminer.pdfinterp importPDFResourceManager, PDFPageInterpreter
from pdfminer.layout importLAParams
from pdfminer.converter importXMLConverter, HTMLConverter, TextConverter
def pdfparser(data):
fp = file(data, 'rb')
resource_manager = PDFResourceManager()
retstr = StringIO()
codec = 'utf-8'
laparams = LAParams()
device = TextConverter(resource_manager,retstr, codec=codec, laparams=laparams)
interpreter =PDFPageInterpreter(resource_manager, device)
# Process each page contained in thedocument.
for page in PDFPage.get_pages(fp):
interpreter.process_page(page)
data = retstr.getvalue()
print data
pdfparser('filename.pdf') 이것은 pdf 파일을 가져와서 PDFPageInterpreter 클래스의 process_page 함수를 사용하여 페이지별로 텍스트를 추출합니다.
텍스트 추출에 사용하기 훨씬 쉬운 API가 있는 PDFMiner의 대안이 있습니다. pyPDF는 잘 작동합니다(잘 구성된 PDF로 작업한다고 가정). 원하는 것이 텍스트(공백 포함)인 경우 다음을 수행할 수 있습니다.
import pyPdf
pdf = pyPdf.PdfFileReader(open('filename.pdf',"rb"))
for page in pdf.pages:
print page.extractText()