Python實(shí)現(xiàn)快速提取PDF文檔中的圖片
提取PDF文檔中的圖片是一項(xiàng)常見的任務(wù),可以通過Python中的一些庫(kù)來實(shí)現(xiàn)。
本文將介紹如何使用PyPDF2和pdfminer.six這兩個(gè)庫(kù)來提取PDF文檔中的圖片。
PyPDF2
PyPDF2是一個(gè)用于處理PDF文件的Python庫(kù),可以用于合并、分割、旋轉(zhuǎn)和提取PDF文件中的文本和圖像等操作。
下面是一個(gè)使用PyPDF2庫(kù)提取PDF文檔中圖片的示例代碼:
import?PyPDF2 #?打開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)
在上面的代碼中,我們首先打開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 #?打開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)
在上面的代碼中,我們首先打開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ù)來提取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)文章
tensorflow mnist 數(shù)據(jù)加載實(shí)現(xiàn)并畫圖效果
TensorFlow™ 是一個(gè)采用數(shù)據(jù)流圖(data flow graphs),用于數(shù)值計(jì)算的開源軟件庫(kù)。這篇文章給大家介紹tensorflow mnist 數(shù)據(jù)加載實(shí)現(xiàn)并畫圖效果,感興趣的朋友一起看看吧2020-02-02python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法
今天小編就為大家分享一篇python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06opencv python簡(jiǎn)易文檔之圖像處理算法
OpenCV是一個(gè)開源庫(kù),包含了許多計(jì)算機(jī)視覺算法,它在計(jì)算機(jī)視覺和圖像處理中起著重要作用,用于實(shí)時(shí)操作,其效率足以滿足工業(yè)上的要求,這篇文章主要給大家介紹了關(guān)于opencv python簡(jiǎn)易文檔之圖像處理算法的相關(guān)資料,需要的朋友可以參考下2021-08-08python圖形開發(fā)GUI庫(kù)wxpython使用方法詳解
這篇文章主要介紹了python GUI庫(kù)wxpython使用方法詳解,需要的朋友可以參考下2020-02-02