本文實(shí)例講述了Python解析并讀取PDF文件內(nèi)容的方法。分享給大家供大家參考,具體如下:
一、問題描述
利用python,去讀取pdf文本內(nèi)容。
二、效果
三、運(yùn)行環(huán)境
python2.7
四、需要安裝的庫
1
|
pip install pdfminer |
五、實(shí)現(xiàn)源代碼
代碼1(win64)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
# coding=utf-8 import sys reload (sys) sys.setdefaultencoding( 'utf-8' ) import time time1 = time.time() import os.path 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 result = [] class CPdf2TxtManager(): def __init__( self ): ''''' Constructor ''' def changePdfToText( self , filePath): file = open (path, 'rb' ) # 以二進(jìn)制讀模式打開 #用文件對(duì)象來創(chuàng)建一個(gè)pdf文檔分析器 praser = PDFParser( file ) # 創(chuàng)建一個(gè)PDF文檔 doc = PDFDocument() # 連接分析器 與文檔對(duì)象 praser.set_document(doc) doc.set_parser(praser) # 提供初始化密碼 # 如果沒有密碼 就創(chuàng)建一個(gè)空的字符串 doc.initialize() # 檢測(cè)文檔是否提供txt轉(zhuǎn)換,不提供就忽略 if not doc.is_extractable: raise PDFTextExtractionNotAllowed # 創(chuàng)建PDf 資源管理器 來管理共享資源 rsrcmgr = PDFResourceManager() # 創(chuàng)建一個(gè)PDF設(shè)備對(duì)象 laparams = LAParams() device = PDFPageAggregator(rsrcmgr, laparams = laparams) # 創(chuàng)建一個(gè)PDF解釋器對(duì)象 interpreter = PDFPageInterpreter(rsrcmgr, device) pdfStr = '' # 循環(huán)遍歷列表,每次處理一個(gè)page的內(nèi)容 for page in doc.get_pages(): # doc.get_pages() 獲取page列表 interpreter.process_page(page) # 接受該頁面的LTPage對(duì)象 layout = device.get_result() for x in layout: if hasattr (x, "get_text" ): # print x.get_text() result.append(x.get_text()) fileNames = os.path.splitext(filePath) with open (fileNames[ 0 ] + '.txt' , 'wb' ) as f: results = x.get_text() print (results) f.write(results + '\n' ) if __name__ = = '__main__' : ''''' 解析pdf 文本,保存到txt文件中 ''' path = u 'C:/data3.pdf' pdf2TxtManager = CPdf2TxtManager() pdf2TxtManager.changePdfToText(path) # print result[0] time2 = time.time() print u 'ok,解析pdf結(jié)束!' print u '總共耗時(shí):' + str (time2 - time1) + 's' |
代碼2(win32)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
# coding=utf-8 import sys reload (sys) sys.setdefaultencoding( 'utf-8' ) import time time1 = time.time() import os.path from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter from pdfminer.converter import PDFPageAggregator from pdfminer.layout import LAParams from pdfminer.pdfpage import PDFTextExtractionNotAllowed from pdfminer.pdfparser import PDFParser from pdfminer.pdfdocument import PDFDocument from pdfminer.pdfpage import PDFPage result = [] class CPdf2TxtManager(): def __init__( self ): ''''' Constructor ''' def changePdfToText( self , filePath): file = open (path, 'rb' ) # 以二進(jìn)制讀模式打開 #用文件對(duì)象來創(chuàng)建一個(gè)pdf文檔分析器 praser = PDFParser( file ) # 創(chuàng)建一個(gè)PDF文檔 doc = PDFDocument(praser) # 檢測(cè)文檔是否提供txt轉(zhuǎn)換,不提供就忽略 if not doc.is_extractable: raise PDFTextExtractionNotAllowed # 創(chuàng)建PDf 資源管理器 來管理共享資源 rsrcmgr = PDFResourceManager() # 創(chuàng)建一個(gè)PDF設(shè)備對(duì)象 laparams = LAParams() device = PDFPageAggregator(rsrcmgr, laparams = laparams) # 創(chuàng)建一個(gè)PDF解釋器對(duì)象 interpreter = PDFPageInterpreter(rsrcmgr, device) pdfStr = '' # 循環(huán)遍歷列表,每次處理一個(gè)page的內(nèi)容 for page in PDFPage.create_pages(doc): # doc.get_pages() 獲取page列表 interpreter.process_page(page) # 接受該頁面的LTPage對(duì)象 layout = device.get_result() for x in layout: if hasattr (x, "get_text" ): # print x.get_text() result.append(x.get_text()) fileNames = os.path.splitext(filePath) with open (fileNames[ 0 ] + '.txt' , 'wb' ) as f: results = x.get_text() print (results) f.write(results + '\n' ) if __name__ = = '__main__' : ''''' 解析pdf 文本,保存到txt文件中 ''' path = u 'C:/36.pdf' pdf2TxtManager = CPdf2TxtManager() pdf2TxtManager.changePdfToText(path) # print result[0] time2 = time.time() print u 'ok,解析pdf結(jié)束!' print u '總共耗時(shí):' + str (time2 - time1) + 's' |
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
原文鏈接:https://blog.csdn.net/u013421629/article/details/72764737