Python實(shí)現(xiàn)快速提取PDF文檔中的圖片
提取PDF文檔中的圖片是一項(xiàng)常見(jiàn)的任務(wù),可以通過(guò)Python中的一些庫(kù)來(lái)實(shí)現(xiàn)。
本文將介紹如何使用PyPDF2和pdfminer.six這兩個(gè)庫(kù)來(lái)提取PDF文檔中的圖片。
PyPDF2
PyPDF2是一個(gè)用于處理PDF文件的Python庫(kù),可以用于合并、分割、旋轉(zhuǎn)和提取PDF文件中的文本和圖像等操作。
下面是一個(gè)使用PyPDF2庫(kù)提取PDF文檔中圖片的示例代碼:
import?PyPDF2
#?打開(kāi)PDF文件
pdf_file?=?open('example.pdf',?'rb')
#?創(chuàng)建PDF閱讀器對(duì)象
pdf_reader?=?PyPDF2.PdfFileReader(pdf_file)
#?遍歷每一頁(yè)
for?page_num?in?range(pdf_reader.numPages):
????#?獲取當(dāng)前頁(yè)
????page?=?pdf_reader.getPage(page_num)
????#?獲取當(dāng)前頁(yè)中的所有XObject對(duì)象
????xobjects?=?page['/Resources']['/XObject'].getObject()
????#?遍歷所有XObject對(duì)象
????for?obj?in?xobjects:
????????#?如果當(dāng)前對(duì)象是圖像
????????if?xobjects[obj]['/Subtype']?==?'/Image':
????????????#?獲取圖像的字節(jié)流
????????????image_data?=?xobjects[obj].getData()
????????????#?保存圖像到文件
????????????with?open('image{}.jpg'.format(page_num),?'wb')?as?f:
????????????????f.write(image_data)
在上面的代碼中,我們首先打開(kāi)PDF文件,然后創(chuàng)建一個(gè)PDF閱讀器對(duì)象。
接著,我們遍歷每一頁(yè),獲取當(dāng)前頁(yè)中的所有XObject對(duì)象,然后遍歷所有XObject對(duì)象,如果當(dāng)前對(duì)象是圖像,就獲取圖像的字節(jié)流并保存到文件中。
pdfminer.six
pdfminer.six是一個(gè)用于提取PDF文本和元數(shù)據(jù)的Python庫(kù),它可以將PDF文檔轉(zhuǎn)換為HTML、XML和文本格式。
下面是一個(gè)使用pdfminer.six庫(kù)提取PDF文檔中圖片的示例代碼:
from?pdfminer.pdfparser?import?PDFParser
from?pdfminer.pdfdocument?import?PDFDocument
from?pdfminer.pdftypes?import?resolve1
from?pdfminer.pdfpage?import?PDFPage
from?pdfminer.pdfinterp?import?PDFResourceManager,?PDFPageInterpreter
from?pdfminer.converter?import?PDFPageAggregator
from?pdfminer.layout?import?LAParams,?LTImage
#?打開(kāi)PDF文件
pdf_file?=?open('example.pdf',?'rb')
#?創(chuàng)建PDF解析器對(duì)象
parser?=?PDFParser(pdf_file)
#?創(chuàng)建PDF文檔對(duì)象
document?=?PDFDocument(parser)
#?創(chuàng)建PDF資源管理器對(duì)象
rsrcmgr?=?PDFResourceManager()
#?創(chuàng)建PDF設(shè)備對(duì)象
laparams?=?LAParams()
device?=?PDFPageAggregator(rsrcmgr,?laparams=laparams)
#?創(chuàng)建PDF解釋器對(duì)象
interpreter?=?PDFPageInterpreter(rsrcmgr,?device)
#?遍歷每一頁(yè)
for?page?in?PDFPage.create_pages(document):
????#?解析當(dāng)前頁(yè)
????interpreter.process_page(page)
????#?獲取當(dāng)前頁(yè)的LTImage對(duì)象
????layout?=?device.get_result()
????for?element?in?layout:
????????if?isinstance(element,?LTImage):
????????????#?獲取圖像的字節(jié)流
????????????image_data?=?element.stream.get_rawdata()
????????????#?保存圖像到文件
????????????with?open('image{}.jpg'.format(page.pageid),?'wb')?as?f:
????????????????f.write(image_data)
在上面的代碼中,我們首先打開(kāi)PDF文件,然后創(chuàng)建一個(gè)PDF解析器對(duì)象和一個(gè)PDF文檔對(duì)象。
接著,我們創(chuàng)建一個(gè)PDF資源管理器對(duì)象、一個(gè)PDF設(shè)備對(duì)象和一個(gè)PDF解釋器對(duì)象。
然后,我們遍歷每一頁(yè),解析當(dāng)前頁(yè)并獲取當(dāng)前頁(yè)的LTImage對(duì)象,如果當(dāng)前對(duì)象是圖像,就獲取圖像的字節(jié)流并保存到文件中。
總結(jié)
本文介紹了如何使用PyPDF2和pdfminer.six這兩個(gè)庫(kù)來(lái)提取PDF文檔中的圖片。
PyPDF2庫(kù)可以用于遍歷PDF文檔中的XObject對(duì)象并提取圖像,而pdfminer.six庫(kù)可以用于解析PDF文檔中的LTImage對(duì)象并提取圖像。
這兩個(gè)庫(kù)都是非常強(qiáng)大和靈活的,可以根據(jù)具體的需求選擇使用。
到此這篇關(guān)于Python實(shí)現(xiàn)快速提取PDF文檔中的圖片的文章就介紹到這了,更多相關(guān)Python提取PDF圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python爬蟲(chóng)添加請(qǐng)求頭代碼實(shí)例
這篇文章主要介紹了python爬蟲(chóng)添加請(qǐng)求頭代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
tensorflow mnist 數(shù)據(jù)加載實(shí)現(xiàn)并畫(huà)圖效果
TensorFlow™ 是一個(gè)采用數(shù)據(jù)流圖(data flow graphs),用于數(shù)值計(jì)算的開(kāi)源軟件庫(kù)。這篇文章給大家介紹tensorflow mnist 數(shù)據(jù)加載實(shí)現(xiàn)并畫(huà)圖效果,感興趣的朋友一起看看吧2020-02-02
python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法
今天小編就為大家分享一篇python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
opencv python簡(jiǎn)易文檔之圖像處理算法
OpenCV是一個(gè)開(kāi)源庫(kù),包含了許多計(jì)算機(jī)視覺(jué)算法,它在計(jì)算機(jī)視覺(jué)和圖像處理中起著重要作用,用于實(shí)時(shí)操作,其效率足以滿足工業(yè)上的要求,這篇文章主要給大家介紹了關(guān)于opencv python簡(jiǎn)易文檔之圖像處理算法的相關(guān)資料,需要的朋友可以參考下2021-08-08
python圖形開(kāi)發(fā)GUI庫(kù)wxpython使用方法詳解
這篇文章主要介紹了python GUI庫(kù)wxpython使用方法詳解,需要的朋友可以參考下2020-02-02

