這篇文章將為大家詳細(xì)講解有關(guān)Python中怎么將Office文件轉(zhuǎn)為PDF,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
成都創(chuàng)新互聯(lián)從2013年開(kāi)始,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元壺關(guān)做網(wǎng)站,已為上家服務(wù),為壺關(guān)各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話(huà):18982081108
在實(shí)戰(zhàn)之前,需要安裝 Python 的 win32com,詳細(xì)安裝步驟如下:
使用 pip 命令安裝
pip install pywin32
如果我們遇到安裝錯(cuò)誤,可以通過(guò)python -m pip install --upgrade pip更新云端的方式再進(jìn)行安裝即可:
python -m pip install --upgrade pip
下載離線(xiàn)安裝包安裝
如果 pip 命令未安裝成功的話(huà)還可以下載離線(xiàn)包安裝,方法步驟如下:首先在官網(wǎng)選擇對(duì)應(yīng)的 Python 版本下載離線(xiàn)包:https://sourceforge.net/projects/pywin32/files/pywin32/Build%20221/ 下載好后傻瓜式安裝好即可。
詳細(xì)代碼如下:
class PDFConverter: def __init__(self, pathname, export='.'): self._handle_postfix = ['doc', 'docx', 'ppt', 'pptx', 'xls', 'xlsx'] # 支持轉(zhuǎn)換的文件類(lèi)型 self._filename_list = list() #列出文件 self._export_folder = os.path.join(os.path.abspath('.'), 'file_server/pdfconver') if not os.path.exists(self._export_folder): os.mkdir(self._export_folder) self._enumerate_filename(pathname) def _enumerate_filename(self, pathname): ''' 讀取所有文件名 ''' full_pathname = os.path.abspath(pathname) if os.path.isfile(full_pathname): if self._is_legal_postfix(full_pathname): self._filename_list.append(full_pathname) else: raise TypeError('文件 {} 后綴名不合法!僅支持如下文件類(lèi)型:{}。'.format(pathname, '、'.join(self._handle_postfix))) elif os.path.isdir(full_pathname): for relpath, _, files in os.walk(full_pathname): for name in files: filename = os.path.join(full_pathname, relpath, name) if self._is_legal_postfix(filename): self._filename_list.append(os.path.join(filename)) else: raise TypeError('文件/文件夾 {} 不存在或不合法!'.format(pathname)) def _is_legal_postfix(self, filename): return filename.split('.')[-1].lower() in self._handle_postfix and not os.path.basename(filename).startswith( '~') def run_conver(self): print('需要轉(zhuǎn)換的文件數(shù)是:', len(self._filename_list)) for filename in self._filename_list: postfix = filename.split('.')[-1].lower() funcCall = getattr(self, postfix) print('原文件:', filename) funcCall(filename) print('轉(zhuǎn)換完成!')
doc/docx 轉(zhuǎn)換為 PDF 部分代碼如下所示:
def doc(self, filename): name = os.path.basename(filename).split('.')[0] + '.pdf' exportfile = os.path.join(self._export_folder, name) print('保存 PDF 文件:', exportfile) gencache.EnsureModule('{00020905-0000-0000-C000-000000000046}', 0, 8, 4) pythoncom.CoInitialize() w = Dispatch("Word.Application") pythoncom.CoInitialize() # 加上防止 CoInitialize 未加載 doc = w.Documents.Open(filename) doc.ExportAsFixedFormat(exportfile, constants.wdExportFormatPDF, Item=constants.wdExportDocumentWithMarkup, CreateBookmarks=constants.wdExportCreateHeadingBookmarks) w.Quit(constants.wdDoNotSaveChanges) def docx(self, filename): self.doc(filename)
ppt/pptx 轉(zhuǎn)換為 PDF 部分代碼如下:
def ppt(self, filename): name = os.path.basename(filename).split('.')[0] + '.pdf' exportfile = os.path.join(self._export_folder, name) gencache.EnsureModule('{00020905-0000-0000-C000-000000000046}', 0, 8, 4) pythoncom.CoInitialize() p = Dispatch("PowerPoint.Application") pythoncom.CoInitialize() ppt = p.Presentations.Open(filename, False, False, False) ppt.ExportAsFixedFormat(exportfile, 2, PrintRange=None) print('保存 PDF 文件:', exportfile) p.Quit() def pptx(self, filename): self.ppt(filename)
def xls(self, filename): name = os.path.basename(filename).split('.')[0] + '.pdf' exportfile = os.path.join(self._export_folder, name) pythoncom.CoInitialize() xlApp = DispatchEx("Excel.Application") pythoncom.CoInitialize() xlApp.Visible = False xlApp.DisplayAlerts = 0 books = xlApp.Workbooks.Open(filename, False) books.ExportAsFixedFormat(0, exportfile) books.Close(False) print('保存 PDF 文件:', exportfile) xlApp.Quit() def xlsx(self, filename): self.xls(filename)
if __name__ == "__main__": # 支持文件夾批量導(dǎo)入 #folder = 'tmp' #pathname = os.path.join(os.path.abspath('.'), folder) # 也支持單個(gè)文件的轉(zhuǎn)換 pathname = "G:/python_study/test.doc" pdfConverter = PDFConverter(pathname) pdfConverter.run_conver()
關(guān)于Python中怎么將Office文件轉(zhuǎn)為PDF就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。