Python:通过Win32模块操作Office对象之打印

目录

一、打印Word文档

1.代码

2.操作图示

(1)Word文件及效果

(2)运行-选择路径-填写文件名-确定

(3)完成-文件生成

(4)打印文件效果展示

二、打印Excel文件

三、打印PPT文件

四、总结


一、打印Word文档

1.代码

from win32com.client.gencache import EnsureDispatch
from win32com.client import constants

Word = EnsureDispatch("Word.Application") # 连接/创建Word对象(打开Word程序)
f = r"E:\Zhuomian_CJ\答网友问\Python\20220725打印Office组件文件\测试.docx"

doc = Word.Documents.Open(f) # 打开Word文档
doc.PrintOut() # 打印(到默认打印机);如果默认打印机为虚拟打印机,则会弹出保存文件对话框(需要选择保存文件的格式和路径)
doc.Close(constants.wdDoNotSaveChanges) # (不保存)关闭Word文档

Word.Quit() # 退出Word程序

2.操作图示

此处默认用的虚拟打印机

默认打印机

(1)Word文件及效果

和代码同一文件夹下有一个【测试.docx】的Word文档

Word文件位置

Word文档效果

(2)运行-选择路径-填写文件名-确定

在Word文件相同文件位置存储打印文件

(3)完成-文件生成

刚刚所选路径已经生成PDF文件

注:此处如果是用的真实打印机,就已经打印出纸质文件。

(4)打印文件效果展示

打印文件

打印Word文件、Excel文件和PPT文件的代码思路都是一样,还可以具体设置各种打印参数。下面就只写打印Excel和PPT文件的示例代码

二、打印Excel文件

from win32com.client.gencache import EnsureDispatch
from win32com.client import constants

Excel = EnsureDispatch("Excel.Application") # 打开Excel程序
f = r"E:\Zhuomian_CJ\答网友问\Python\20220725打印Office组件文件\测试.xlsx"

wb = Excel.Workbooks.Open(f) # 打开Excel工作簿
sht = wb.Sheets("Sheet1") # 指定工作表
sht.PrintOut() # 打印工作表
wb.Close(constants.xlDoNotSaveChanges) # (不保存)关闭工作簿

Excel.Quit() # 退出Excel程序

注意:Excel工作簿每次只能打印里面的一张表格,如需打印所有工作表,需要循环。

三、打印PPT文件

from win32com.client.gencache import EnsureDispatch
from win32com.client import constants

PPT = EnsureDispatch('PowerPoint.Application') # 打开PPT程序
f = r"E:\Zhuomian_CJ\答网友问\Python\20220725打印Office组件文件\测试.pptx"

prs = PPT.Presentations.Open(f) # 打开PPT文件
prs.PrintOut() # 打印
prs.Close() # 关闭PPT文件

PPT.Quit() # 退出PPT程序

四、总结

此文主要展示三种文件打印的示例代码,具体参数等可以参考我之前的几篇VBA的文章中的VBA代码,因为Win32中的代码书写方式和VBA中基本一样。

守候:Excel VBA:批量对文件任意重命名(移动)icon-default.png?t=M666https://zhuanlan.zhihu.com/p/541264248

守候:PPT VBA:批量转PDFicon-default.png?t=M666https://zhuanlan.zhihu.com/p/544109509

之所以用Win32模块,是因为它是最全面的。只要在这些文件中可以手动设置的属性,全部可以通过代码实现。

如果此文对您用Python操作Office文档有帮助和启发,别忘记帮忙点赞,收藏,评论和转发。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Python使用Win32com可以方便地与Windows系统进行交互,如操作Office软件、发送邮件等等。以下是我的一些心得体会: 1. 安装pywin32模块 在使用Win32com之前,需要先安装pywin32模块。可以通过pip install pywin32命令进行安装。 2. 使用win32com.client模块 使用Win32com时,需要导入win32com.client模块。该模块提供了许多常用的COM接口,如操作Office软件的接口、发送邮件的接口等。 3. 操作Office软件 使用Win32com可以方便地操作Office软件,如Word、Excel等。通过创建COM对象,可以打开Office软件并对其进行操作,如设置文本、表格、图表等。以下是一个简单的操作Word的示例代码: ```python import win32com.client as win32 # 创建Word对象 word = win32.gencache.EnsureDispatch('Word.Application') # 打开Word文档 doc = word.Documents.Open(r'C:\test.docx') # 遍历文档中的段落 for para in doc.Paragraphs: print(para.Range.Text) # 关闭Word文档 doc.Close() # 退出Word应用程序 word.Quit() ``` 4. 发送邮件 使用Win32com可以方便地发送邮件。通过创建COM对象,可以连接到邮件服务器并发送邮件。以下是一个简单的发送邮件的示例代码: ```python import win32com.client as win32 # 创建Outlook对象 outlook = win32.Dispatch('Outlook.Application') # 创建邮件对象 mail = outlook.CreateItem(0) # 设置邮件收件人、主题和正文 mail.To = 'xxx@xxx.com' mail.Subject = '测试邮件' mail.Body = '这是一封测试邮件!' # 发送邮件 mail.Send() # 退出Outlook应用程序 outlook.Quit() ``` 总之,使用Win32com可以方便地与Windows系统进行交互,提高工作效率。但需要注意的是,使用Win32com时需要了解COM接口的相关知识,以便更好地进行开发。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

VBA-守候

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值