Python利用PyMuPDF模塊實(shí)現(xiàn)快速轉(zhuǎn)換PDF文件
解決問題
有時(shí)候?qū)⑽臋n上傳Claude2做分析,有大小限制,所以需要切割pdf文檔為幾個(gè)小點(diǎn)的文檔,故才有了本文章。
如何用Python和PyMuPDF制作你想要大小的PDF?
PDF是一種廣泛使用的文件格式,可以在任何設(shè)備上查看和打印。但是,有時(shí)您可能只需要查看PDF文件中的前幾頁,而不是整個(gè)文件。在這種情況下,將PDF文件轉(zhuǎn)換為只包含指定頁數(shù)的新文件可能是有用的。本文將介紹如何使用Python和PyMuPDF模塊來實(shí)現(xiàn)此任務(wù)。
安裝PyMuPDF模塊
在使用PyMuPDF之前,我們需要先安裝它??梢允褂靡韵旅顏戆惭bPyMuPDF:
pip install PyMuPDF
導(dǎo)入PyMuPDF和wxPython模塊
接下來,我們需要導(dǎo)入PyMuPDF和wxPython模塊:
import fitz import wx
創(chuàng)建GUI界面
為了方便用戶輸入PDF文件和頁碼數(shù)量,我們將創(chuàng)建一個(gè)簡單的GUI界面。我們將使用wxPython模塊來創(chuàng)建GUI界面。以下是代碼示例:
class PDFExtractorFrame(wx.Frame): def __init__(self, *args, **kw): super(PDFExtractorFrame, self).__init__(*args, **kw) panel = wx.Panel(self) vbox = wx.BoxSizer(wx.VERTICAL) self.file_picker = wx.FilePickerCtrl(panel, message="選擇PDF文件", wildcard="PDF Files (*.pdf)|*.pdf", style=wx.FLP_DEFAULT_STYLE | wx.FLP_USE_TEXTCTRL) vbox.Add(self.file_picker, 0, wx.EXPAND | wx.ALL, 10) self.page_input = wx.TextCtrl(panel, value="1", style=wx.TE_PROCESS_ENTER) vbox.Add(self.page_input, 0, wx.EXPAND | wx.ALL, 10) extract_button = wx.Button(panel, label="提取", size=(70, 30)) extract_button.Bind(wx.EVT_BUTTON, self.on_extract) vbox.Add(extract_button, 0, wx.ALIGN_CENTER | wx.ALL, 10) panel.SetSizer(vbox) self.Bind(wx.EVT_TEXT_ENTER, self.on_extract, self.page_input)
此代碼創(chuàng)建一個(gè)名為PDFExtractorFrame的wx.Frame類,并在其構(gòu)造函數(shù)中創(chuàng)建GUI界面元素。它創(chuàng)建了一個(gè)wx.Panel對象和兩個(gè)wx.BoxSizer對象來放置GUI元素。在此GUI界面中,用戶可以選擇PDF文件和輸入要保留的頁碼數(shù)量。
實(shí)現(xiàn)轉(zhuǎn)換功能
接下來,我們需要實(shí)現(xiàn)轉(zhuǎn)換功能。我們將使用PyMuPDF模塊來打開PDF文件,并使用它來復(fù)制指定數(shù)量的頁面。以下是代碼示例:
def extract_pages(self, input_pdf, page_number, output_pdf): # 打開PDF文檔 pdf_document = fitz.open(input_pdf) total_pages = pdf_document.page_count # 確保頁碼不超過文檔的總頁數(shù) page_number = min(page_number, total_pages) # 創(chuàng)建新的PDF文檔,只包含指定頁碼之前的內(nèi)容 pdf_writer = fitz.open() for page in range(page_number): pdf_writer.insert_pdf(pdf_document, from_page=page, to_page=page) # 保存新的PDF文檔到指定路徑 pdf_writer.save(output_pdf) pdf_writer.close() pdf_document.close()
此代碼使用PyMuPDF模塊將PDF文件轉(zhuǎn)換為只包含前N頁的新PDF文件的函數(shù)。該函數(shù)將源PDF文件路徑,要提取的頁數(shù)和新PDF文件的輸出路徑作為參數(shù),并返回?zé)o返回值。以下是該函數(shù)的詳細(xì)說明:
- input_pdf: 源PDF文件的路徑。
- page_number: 要提取的頁數(shù)。
- output_pdf: 新PDF文件的輸出路徑。
該函數(shù)使用fitz.open()函數(shù)打開輸入PDF文件并獲取其總頁數(shù)。如果指定的頁碼數(shù)量超過文檔的總頁數(shù),則將其設(shè)置為文檔的總頁數(shù)。
在創(chuàng)建新的PDF文檔之前,該函數(shù)創(chuàng)建一個(gè)空的PDF文檔對象。然后,它使用insert_pdf()函數(shù)從源PDF文件中復(fù)制每個(gè)頁面,并將其插入到新的PDF文檔對象中。該函數(shù)只復(fù)制指定數(shù)量的頁面。
最后,該函數(shù)使用save()函數(shù)將新PDF文檔保存到指定的輸出路徑,并使用close()函數(shù)關(guān)閉所有打開的PDF文檔對象以釋放資源。
運(yùn)行應(yīng)用程序
完整代碼
import fitz # PyMuPDF import wx class PDFExtractorApp(wx.App): def OnInit(self): self.frame = PDFExtractorFrame(None, title="PDF頁面提取工具") self.SetTopWindow(self.frame) self.frame.Show() return True class PDFExtractorFrame(wx.Frame): def __init__(self, *args, **kw): super(PDFExtractorFrame, self).__init__(*args, **kw) panel = wx.Panel(self) vbox = wx.BoxSizer(wx.VERTICAL) self.file_picker = wx.FilePickerCtrl(panel, message="選擇PDF文件", wildcard="PDF Files (*.pdf)|*.pdf", style=wx.FLP_DEFAULT_STYLE | wx.FLP_USE_TEXTCTRL) vbox.Add(self.file_picker, 0, wx.EXPAND | wx.ALL, 10) self.page_input = wx.TextCtrl(panel, value="1", style=wx.TE_PROCESS_ENTER) vbox.Add(self.page_input, 0, wx.EXPAND | wx.ALL, 10) extract_button = wx.Button(panel, label="提取", size=(70, 30)) extract_button.Bind(wx.EVT_BUTTON, self.on_extract) vbox.Add(extract_button, 0, wx.ALIGN_CENTER | wx.ALL, 10) panel.SetSizer(vbox) self.Bind(wx.EVT_TEXT_ENTER, self.on_extract, self.page_input) def on_extract(self, event): input_pdf = self.file_picker.GetPath() output_pdf = "output.pdf" try: page_number = int(self.page_input.GetValue()) self.extract_pages(input_pdf, page_number, output_pdf) wx.MessageBox("PDF頁面提取完成!", "成功", wx.OK | wx.ICON_INFORMATION) except ValueError: wx.MessageBox("無效的頁碼輸入!", "錯(cuò)誤", wx.OK | wx.ICON_ERROR) def extract_pages(self, input_pdf, page_number, output_pdf): # 打開PDF文檔 pdf_document = fitz.open(input_pdf) total_pages = pdf_document.page_count # 確保頁碼不超過文檔的總頁數(shù) page_number = min(page_number, total_pages) # 創(chuàng)建新的PDF文檔,只包含指定頁碼之前的內(nèi)容 pdf_writer = fitz.open() for page in range(page_number): pdf_writer.insert_pdf(pdf_document, from_page=page, to_page=page) # 保存新的PDF文檔到指定路徑 pdf_writer.save(output_pdf) pdf_writer.close() pdf_document.close() if __name__ == '__main__': app = PDFExtractorApp() app.MainLoop()
以上就是Python利用PyMuPDF模塊實(shí)現(xiàn)快速轉(zhuǎn)換PDF文件的詳細(xì)內(nèi)容,更多關(guān)于Python PyMuPDF轉(zhuǎn)換PDF的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python使用openpyxl批量處理數(shù)據(jù)
openpyxl 是一個(gè)用于處理 xlsx 格式Excel表格文件的第三方python庫,其支持Excel表格絕大多數(shù)基本操作。本文給大家介紹Python使用openpyxl批量處理數(shù)據(jù)的操作方法,感興趣的朋友一起看看吧2021-06-06使用Python paramiko模塊利用多線程實(shí)現(xiàn)ssh并發(fā)執(zhí)行操作
ssh是一個(gè)協(xié)議,OpenSSH是其中一個(gè)開源實(shí)現(xiàn),paramiko是Python的一個(gè)庫,實(shí)現(xiàn)了SSHv2協(xié)議(底層使用cryptography)。這篇文章主要介紹了使用Python paramiko模塊利用多線程實(shí)現(xiàn)ssh并發(fā)執(zhí)行操作,需要的朋友可以參考下2019-12-12python被修飾的函數(shù)消失問題解決(基于wraps函數(shù))
這篇文章主要介紹了python被修飾的函數(shù)消失問題解決(基于wraps函數(shù)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11Python中如何實(shí)現(xiàn)真正的按位取反運(yùn)算
按位取反是位運(yùn)算符,而位運(yùn)算符是應(yīng)用在兩個(gè)數(shù)的運(yùn)算上,會對數(shù)字的二進(jìn)制所有位數(shù)進(jìn)行從低到高的運(yùn)算,下面這篇文章主要給大家介紹了關(guān)于Python中如何實(shí)現(xiàn)真正的按位取反運(yùn)算的相關(guān)資料,需要的朋友可以參考下2023-02-02Python中關(guān)于?*args與**args的用法及說明
這篇文章主要介紹了Python中關(guān)于?*args與**args的用法及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02MoviePy常用剪輯類及Python視頻剪輯自動(dòng)化
這篇文章主要介紹了MoviePy常用剪輯類及Python視頻剪輯自動(dòng)化,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12