Python pywin32实现word和Excel的处理

这篇具有很好参考价值的文章主要介绍了Python pywin32实现word和Excel的处理。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

pywin32处理Word和Excel的一些事

我们知道Python处理word和Excel的可以借助第三库python-docx、xlrd、xlwt和openpyxl等实现,但这些模块只支持基本的读写操作,如果要实现一些较为深入功能,就要看模块是否有相应功能支持了。
例如将word和Excel转为pdf,在word和Excel里面执行VBA实现特殊功能,在Excel里面生成数据透视表、设置Excel的页面设置等等。
除了使用上述模块之外,还可以直接使用pywin32实现word和Excel的操作,其底层原理是通过win32com实现操作,不过pywin32目前只能在Windows上运行,对linux和macos不太友好,并且电脑必须安装wps或微软office,这也是pywin32的一些局限。

pywin32将Word转pdf

pywin32处理Word大多数用于格式转换,因为一般读写操作都可以借助python-docx实现,除非真的有特殊要求,但大部分企业对Wrod操作不会有太多复杂需求。
废话不多说,直接上代码

pythoncom.CoInitialize()
file_path = 'xxxx'
try:
	word = wc.gencache.EnsureDispatch('word.application')
except:
	try:
		word = wc.gencache.EnsureDispatch('kwps.application')  # 如果使用wps
	except:
		word = wc.gencache.EnsureDispatch('wps.application')  # 如果使用wps
newpdf = word.Documents.Open(file_path)
word.Visible = 0
newpdf.SaveAs(f'xxxx.pdf', FileFormat=17)
newpdf.Close()
pythoncom.CoUninitialize()

使用pywin32创建Word对象可以使用微软Excel(word.application)或Wps实现(kwps.application或wps.application),wps的kwps和wps主要是wps版本不同导致的,这个要看电脑安装是那个版本的Wps。
使用win32com调用com组件的时候,需要用pythoncom.CoInitialize初始化一下,最后还需要用pythoncom.CoUninitialize释放资源。

pywin32将Excel格式处理并转pdf

由于pywin32处理Excel没有相应官方文档说明,也没有相应源码,那怎办?实际上,官方文档在微软官方文档有说明的,打开微软官方文档可以发现,文档是以VBA为主,换句话说,我们需要将VBA代码转换为Python代码。
如果不太熟悉VBA代码,可以打开Excel录制宏代码,录制过程中将用户操作Excel转换为VBA代码,如图所示
Python pywin32实现word和Excel的处理
关于Excel设置开发者工具,如何录制VBA代码这个自行百度一下了。
然后从VBA代码在官方文档找到对应属性,比如VBA代码的PageSetup是Excel的页面设置,在官方文档找到PageSetup相关属性方法,
按照上述,VBA转换对应Python如下:

from win32com import client as wc

try:
    excel = wc.DispatchEx('Excel.Application')
except:
    try:
        excel = wc.DispatchEx('ket.Application')
    except:
        excel = wc.DispatchEx('et.Application')
newpdf = excel.Workbooks.Open(r'C:\Users\Administrator\Desktop\tt\abc.xls')
excel.DisplayAlerts = 0
# 获取第一个sheet
all_sheets = [sheet.Name for sheet in newpdf.Sheets]
ws_source = newpdf.Worksheets(all_sheets[0])
# 设置页面设置
ws_source.PageSetup.LeftHeader = ""
ws_source.PageSetup.CenterHeader = ""
ws_source.PageSetup.RightHeader = ""
ws_source.PageSetup.LeftFooter = ""
ws_source.PageSetup.CenterFooter = ""
ws_source.PageSetup.RightFooter = ""
# ws_source.PageSetup.FitToPagesTall = 0
ws_source.PageSetup.FirstPageNumber = True
ws_source.PageSetup.LeftMargin = 0
ws_source.PageSetup.RightMargin = 0
ws_source.PageSetup.TopMargin = 0
ws_source.PageSetup.BottomMargin = 0
ws_source.PageSetup.HeaderMargin = 0
ws_source.PageSetup.FooterMargin = 0
# ws_source.PageSetup.PaperSize = 1
ws_source.PageSetup.Orientation = 2  # 横向转换pdf
ws_source.PageSetup.FitToPagesWide = 1  # 所有列压缩在一页纸
ws_source.PageSetup.FitToPagesTall = False
ws_source.PageSetup.Zoom = False  # 所有列压缩在一页纸
ws_source.PageSetup.CenterVertically = True
ws_source.PageSetup.CenterHorizontally = True
ws_source.PageSetup.Draft = False
ws_source.Select()
# 行列自动调整
# ws_source.Columns.AutoFit()
# ws_source.Rows.AutoFit()
# 设置Excel的边框
rows = ws_source.UsedRange.Rows.Count
cols = ws_source.UsedRange.Columns.Count
ws_source.Range(ws_source.Cells(1, 1), ws_source.Cells(rows, cols)).Borders.LineStyle = 1
ws_source.Range(ws_source.Cells(1, 1), ws_source.Cells(rows, cols)).Borders.TintAndShade = 0
ws_source.Range(ws_source.Cells(1, 1), ws_source.Cells(rows, cols)).Borders.Weight = 1
# 转换为PDF文件
newpdf.ExportAsFixedFormat(0, r'C:\Users\Administrator\Desktop\tt\abc.pdf')
newpdf.Close()
excel.Quit()

从Python代码看到,它与VBA代码十分相似,也就是说,VBA能实现的功能,Python也能实现,说明了,编程语言只是工具,不管是什么工具,只要玩的溜就行了。

总结

从微软官方文档看到,VBA还支持office所有软件,如Access、outlook、ppt等等开发,那么Python使用pywin32也能实现这些开发。不管如此,还可以实现Windows其他功能开发,如自动打印功能使用win32print,这都是pywin32模块。
更多内容请关注公众号
Python pywin32实现word和Excel的处理文章来源地址https://www.toymoban.com/news/detail-445078.html

到了这里,关于Python pywin32实现word和Excel的处理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • python word中插入excel文件以图标显示(win32com调用vba代码)

    参考文章:(5条消息) python extension(pywin32) 插入宏到word_hit_liuanhuaming的专栏-CSDN博客   功能需求:在C:UsersuserDesktop20210408-1xxx.docx中插入xxx.xlsx文件以图标显示,如下图:   1.准备: 1)python模块安装: 2)word启用宏功能: 文件-选项 信任中心-信任中心设置 勾选信任对VBA工程对象模型

    2023年04月08日
    浏览(29)
  • Python的Pywin32库:简化Windows编程的强大工具

    导言: Python是一种功能强大的编程语言,广泛用于各个领域。然而,当涉及到Windows操作系统的编程时,可能会遇到一些挑战。这时,Pywin32库就派上了用场。Pywin32是一个开源的Python扩展库,提供了访问Windows API的接口,使得在Python中进行Windows编程变得轻而易举。本文将介绍

    2024年02月14日
    浏览(33)
  • 用python实现excel表格插入word

    你可以使用Python中的 python-docx 和 openpyxl 库来实现将Excel表格插入Word文档。下面是一个示例代码,可以将一个名为\\\"example.xlsx\\\"的Excel表格插入到一个名为\\\"example.docx\\\"的Word文档中: python复制代码 import openpyxl from docx import Document # 打开Word文档 doc = Document(\\\"example.docx\\\") # 打开Excel表格

    2024年01月19日
    浏览(38)
  • 【Python】解决pywin32各种常见问题及中英文手册下载(详细)

    目录 前言 一、中英文手册获取 二、各种常见问题 1. ModuleNotFoundError: No module named \\\'win32xxx\\\' 2. ImportError:DLL load failed while importing win32xxx: 找不到指定的模块。 方法一 方法二 方法三 3. pywintypes.error: (2, \\\'XXX\\\', \\\'系统找不到指定的文件。\\\') 总结 pywin32是针对微软Windows的Python扩展,p

    2024年02月07日
    浏览(33)
  • Python实现Word、Excel、PPT批量转为PDF

    今天看见了一个有意思的脚本Python批量实现Word、EXCLE、PPT转PDF文件。 因为我平时word用的比较的多,所以深有体会,具体怎么实现的我们就不讨论了,因为这个去学了也没什么提升,不然也不会当作脚本了。这里我将其放入了pyzjr库中,也方便大家进行调用。 你可以去下载p

    2024年02月10日
    浏览(49)
  • Python操作Word:轻松实现文档的创建、编辑与自动化处理

    引言: 在日常工作和学习中,我们经常需要使用Microsoft Word来创建、编辑和处理文档。然而,手动操作Word可能会耗费大量的时间和精力。为了提高工作效率,我们可以使用Python编程语言来操作Word文档,实现文档的自动化处理。本文将详细介绍如何使用Python操作Word,包括创建

    2024年01月21日
    浏览(43)
  • 使用Python的win32com库实现对Word的操作

    win32com库是Python中的一个扩展库,它提供了与Microsoft Office应用程序进行交互的功能。在本篇博客中,我们将重点介绍如何使用win32com库来操作Word文档。使用win32com库可以方便地打开、创建、保存和编辑Word文档,以及进行格式化和布局等操作。 要使用win32com库,首先需要安装它

    2024年02月06日
    浏览(26)
  • python使用win32com库实现对Excel的操作

    在日常工作中,我们经常需要对Excel文件进行操作,例如读取和写入数据、格式化和样式、插入和删除等。而使用Python的win32com库,我们可以通过代码来实现对Excel的自动化操作,提高工作效率和准确性。 本篇博客将介绍如何使用win32com库来操作Excel,包括安装和配置、创建和

    2024年02月14日
    浏览(25)
  • Python 基于win32com客户端实现Excel操作

    Python 3.6.2 新建并保存EXCEL 了解更多API,可以查看参考连接 读取现有EXCEL 说明: 如果不添加以下代码行: 会报错,如下: 建议使用 替代 实践发现,多线程的情况下,使用 Dispatch 会出现报错,原因似乎是 Dispatch 若发现进程已经存在的话,就不会创建新的进程。若不创建新的

    2024年02月01日
    浏览(81)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包