在使用PC时与PC交互的主要途径是看屏幕显示、听声音,点击鼠标和敲键盘等等。在自动化办公的趋势下,繁琐的工作可以让程序自动完成。比如自动化测试、自动下单交易等。很多软件除了可以GUI方式操作外还可以用CLI接口操作,不过当一些软件未提供CLI接口时,我们应该怎么办呢?我们还可以用程序控制桌面上的窗口、模拟点击鼠标或按下键盘等动作来释放自己。
pywin32是一个Python库,它为Python提供访问Windows API的扩展,提供了齐全的windows常量、接口、线程以及COM机制等等,安装后会自带一个pythonwin的IDE。接下来主要介绍下如何通过Python去操作windows桌面软件。
1、打开软件或文件 ,比如打开一个谷歌浏览器,或者打开一个word文件,如下所示:
win32api.ShellExecute(1, 'open',
r'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe',
'', '', 1)
win32api.ShellExecute(1, 'open',
r'C:\Users\Jay\Desktop\Environment Guider.docx',
'', '', 1)
win32api.ShellExecute()的参数主要包括:
HWND:指定父窗口句柄
Operation:指定动作, 譬如"edit",“explore”,“open”,“find”,“print”,“NULL”
FileName:指定要打开的文件或程序
Parameters:指定打开程序所需参数
Directory:缺省目录
ShowCmd:打开选项,可选值:
执行成功会返回应用程序句柄, 如果返回值 <= 32,则表示执行错误。返回值可能的错误有:
0—— {内存不足}
2—— {文件名错误}
3—— {路径名错误}
11—— {EXE 文件无效}
26