百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

python自动化工具:pywinauto(pythonapp自动化)

myzbx 2025-04-08 16:43 7 浏览

简介

Pywinauto是完全由Python构建的一个模块,可以用于自动化 Windows 上的 GUI 应用程序。同时,它支持鼠标、键盘操作,在元素控件树较复杂的界面,可以辅助我们完成自动化操作。

我在工作中,主要是使用pywinauto来辅助做一些操作,来完成自动化测试。

pywinauto安装

先要确认本地有python环境,然后可以通过命令行安装pywinauto:

pip install pywinauto

如果你是使用ide,可以通过ide安装,比如我习惯使用pycharm,就可以在Project Interpreter中添加pywinauto:

还有一些手动安装的方法,但是有点繁琐,不是很推荐,这里就不介绍了。

访问技术选择

Pywinauto要操作应用,首先需要访问应用,主要有两种访问技术。WIN32访问技术支持MFC、VB6、VCL、简单WinForms控件开发的应用,MS UI Automation访问技术支持WinForms、WPS、QT5、WPF、Store apps、browsers等开发的应用。

win32 API的backend为「 win32 」,MS UI Automation的backend为「 uia 」。

Pywinauto中使用的backend默认为win32。可使用spy++或者Inspect工具判断backend适合选哪种。例如:如果使用py_inspect的uia模式,可见的控件和属性更多的话,backend可选uia,反之,backend可选win32。

这里提一下常用的分析工具:

  • SPY++,用于WIN32 API。当SPY++可以显示所有的控件时,访问技术应该选择"win32"。
  • Inspect.exe:如果Inspect.exe的模式设置为UIA模式,可以比SPY++显示更多的控件,则访问技术应该选择"uia"。
  • py_inspect:支持win32和uia两种访问技术,是SWAPY的替代。
  • UISPY:支持uia访问技术。
  • SWAPY:只支持win32访问技术。

我个人常用的是py_inspect和spy++。

打开应用

多数情况下都是需要打开应用的,实现方式也很简单:

app = Application(backend='uia').start('D:\WireShark\Wireshark.exe')

backend参数根据实际情况选择传uia还是win32。

start方法其实可以传两个参数,除了目标应用的启动程序地址,还可以传一个timeout,如果不传,默认是5s。如果你的目标程序启动、运行都很慢,可以将timeout设置久一点。

连接应用

如果要操控的应用已经处于启动状态,可以直接进行连接,而连接方式有多种可以选择:

# 通过应用完整路径
app = Application(backend='uia').connect(path="D:\WireShark\Wireshark.exe")
# 通过应用进程pid进行连接
app = Application(backend='uia').connect(process=pid)

其中Windows的pid可以通过任务管理器进行查看:

# 通过窗口句柄
app = Application(backend='uia').connect(handle=175)

但是我在实际操作的时候使用窗口句柄没有成功过,可能是我使用姿势不对,不过还是不推荐使用窗口句柄。

# 通过组合参数
app = Application(backend='uia').connect(title_re='Wire', class_name='MainWindow')

title_re参数传递的是应用的部分名称,class_name可以通过py_inspect查询到。

window,dialog定位

前面获取的对象都是应用,但是我们实际操作的是应用窗口,这里就来介绍怎么获取窗口和对话框。

最常用的是通过title定位:

window = app.window(title='Wireshark')

如果不清楚定位工具中的title在哪个位置,显示的是什么,可以通过print_control_identifiers()方法将所有的title都打印出来:

通过title定位的时候需要注意一下中英文的影响,如果是中文,可能会有编码问题,需要转码。

title其实只是window()方法中的一种关键字参数,window()方法可以接收很多中的关键字参数,且这些参数可以组合使用,例如这样:

window = app.window(title='Wireshark', class_name='MainWindow')

主要参数有这些:

  • class_name:ClassName
  • class_name_re:正则匹配window Classname
  • title:Name Window窗口名
  • title_re:正则匹配窗口名
  • best_match:模糊匹配类似的title
  • handle:句柄
  • framework_id:FrameworkId(一般情况下FrameworkId不是唯一的)
  • process:ProcessId,进程id(注意:每次启动后,进程id都会变)
  • control_id:在py_inspect可以查询到
  • control_type:在py_inspect可以查询到
  • auto_id:在py_inspect可以查询到

通过top_window()也能比较容易地获取到窗口,但是这个方法获取的是程序的顶级窗口,但可能不是Z-Order中的顶级窗口。所以这个方法使用的时候多调试几次。

窗口操作

窗口的操作主要有最小化、最大化、恢复、关闭窗口:

# 最小化窗口
dlg.minimize()
 
# 最大化窗口
dlg.maximize()
 
# 恢复窗口
dlg.restore()
 
# 关闭窗口
dlg.close()

control定位

控件的定位其实和窗口的定位基本一致,不太清楚为什么pywinauto在设计的时候会将窗口和控件作为一类东西。

相对于前面定位窗口的window()方法,定位控件的时候推荐使用child_window(),因为直接使用windows()的话,如果控件不是在当前窗口的子控件,是子子控件,就会定位不到,而child_window()方法就不会有这个问题,当然相对的缺点就是当控件深度太深的时候,执行这个方法会比较耗时。

child_window()方法传递的参数和window()是一样的。

控件操作

控件自带了一些操作方法:

# 单击
click_input() 
# 双击
double_click_input  
# 右击
right_click_input  

当这些不好用的时候,比如你的控件不支持点击,但是你又想点击一下,可以使用鼠标操作的一些方法:

# 导入鼠标方法
from pywinauto import mouse
# 点击鼠标左键,coords传的是像素位置
mouse.click(coords=(x,y))
# wheel_dist:为正向上滚动,为负向下滚动
mouse.mouse.scroll(coords=(x,y),wheel_dist=-1)

截图

测试过程中可能会需要截图作为证据,截图的方法也比较简单:

button = app.window(best_match='Unsaved').child_window(best_match='Cancel')
if button.exists(): 
		button..capture_as_image().save(img_path)

模拟键盘的操作

pywinauto也提供了键盘操作的方法:

# 导入键盘方法
from pywinauto.keyboard import *
# 全选
send_keys("^a") 
# “+”:Shift
# “^”:Ctrl
# “%”:Alt

等待机制

pywinauto有几个设置等待时间的方式,这里介绍一个:

# 等待窗口,超时时间是10s,重试1次
window.wait(wait_for='ready',timeout=10,retry_inteval=1)

实战

这里简单的演示一下用Wireshark自动抓包并保存:

import time

from pywinauto import Application, Desktop, mouse
from pywinauto.keyboard import send_keys


def click_control(control):
    control_rect = control.rectangle()
    top = control_rect.top
    bottom = control_rect.bottom
    left = control_rect.left
    right = control_rect.right
    mouse.click(coords=(int((left+right)/2), int((top+bottom)/2)))

app = Application(backend='uia').start('D:\WireShark\Wireshark.exe')
window = app.window(best_match='Wireshark')
time.sleep(5)
window.set_focus()
app.window(best_match='Wireshark').child_window(best_match='WLAN').double_click_input()
time.sleep(5)
app.window(best_match='正在捕获').child_window(best_match='停止').click_input()
app.window(best_match='*WLAN').child_window(best_match='文件').click_input()
app.window(best_match='*WLAN').child_window(best_match='另存为').click_input()
click_control(app.window(best_match='*WLAN').child_window(best_match='文件名(N)'))
send_keys('aaa')
app.window(best_match='*WLAN').child_window(best_match='保存').click_input()

总结

PC端自动化测试使用到的python模块主要有pywinauto、win32gui、pyautogui。这里介绍的pywinauto主要使用到Application类,用于应用程序管理(打开与关闭应用等)、窗口管理(最小化、最大化、关闭窗口)、控件操作。

pywinauto的功能其实挺丰富的,但是真正用到的其实只是其中很小的一块,感兴趣的同学可以多去官网翻一翻。

相关推荐

一键生成高颜值图表!让你的文字瞬间有画面感,职场人必备!

哈喽,打工人们!忙碌的周中,大熊又来给你们带来一个超实用的效率神器啦!这次的宝藏网站绝对是那种用过就离不开的"真香"型产品!假设你明天就要做重要汇报,可面对一大堆密密麻麻的文字材料,你...

批量将 Word 转换为 PDF/Excel/Txt/图片等多种格式

Word文档是我们工作中经常会打交道的一种文档格式,我们也经常会有需要对Word文档进行格式转换的需求,比如将Word格式转换为PDF、将Word文档转换为Excel、将Word...

绝了!一键用AI生成高颜值动态PPT(附详细步骤+Prompt)

大家好,我是一名酷爱研究AI的产品经理,最近我有个新发现:那些花了你3天做出来的PPT,现在用AI可以1小时搞定!而且颜值还高!为什么AI做PPT比传统方式效率高10倍?我用一张图就能告诉你:AI生成...

ztext - 简单几行代码创建酷炫3D特效文字的开源JS库

把网页上的文字变成酷炫的3D风格,还能制作旋转动效,有了ztext.js,只需要几行代码。ztext能做什么ztext.js是一个能把常规的平面文字变成3D样式的前端开源代码库,让开发者...

文字内插入小图片,也太可爱了吧(文字中怎么插图片)

图文排版H5手机版秀米有小伙伴留言问添加图片的时候可不可以把图片添加到文字之间比如下面这句话中的小贴纸图片后面可以接着输入文字其实吧这就是咱们的『文字内插入小图片』功能嘛可以用来在文字内加个表情包又...

Linux环境下C++代码性能分析方法(linux怎么写c++代码)

技术背景在开发C++应用程序时,找出代码中运行缓慢的部分是进行性能优化的关键。在Linux系统上,有多种工具和方法可用于对C++代码进行性能分析,每种方法都有其特点和适用场景。实现步骤手动中断调试法在...

SVG互动图文,让你的文章更有趣!教你4种简单易学的黑科技玩法!

如果你是一个公众号创作者,那么你一定想知道如何让你的文章更加吸引人,更加有趣,更加有创意。你可能已经尝试过各种图文排版技巧,但是你是否知道,有一种黑科技可以让你的文章变得更加酷炫,更加互动,更加爆款?...

Videoscribe怎么实现实心中文汉字的手绘制作

很多朋友在制作手绘视频的时候,不知道怎么输入实心的中文汉字,之前我们已经给大家分享了怎么输入汉字的方法,但是有一点遗憾的是输出的汉字是空心的手绘展示,在视觉上并不是非常的美观。经过大家不断的探索,终于...

一款用于将文本转化成图表的现代化脚本语言

大家好,又见面了,我是GitHub精选君!今天要给大家推荐一个GitHub开源项目terrastruct/d2,该项目在GitHub有超过10.3kStar,用一句话介绍该项目就是:...

探秘 Web 水印技术(制作水印网站)

作者:fransli,腾讯PCG前端开发工程师Web水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印)...

不忍心卸载的五款神仙工具(不忍心卸载的五款神仙工具是什么)

001.效率工具uTools-装机必备的生产力工具集uTools是一款非常强大的可以装下几乎所有效率工具的电脑生产力工具集,目前拥有Windows、Mac和Linux三个版本。软件界面...

「SVG」飞花令!这份最高检工作报告“超有料”

原标题:【SVG】飞花令!这份最高检工作报告“超有料”栏目主编:秦红文字编辑:沈佳灵来源:作者:最高人民检察院...

svg|2025政府工作报告,有没有你关心的数据?

··<setattributeName="visibility"begin="click+0s"dur="1ms"fill="freeze"restart="never"to="hi...

videoscribe只能输入英文,如何输入中文文本?

videoscribe只能输入英文,如何输入中文文本?打开VideoScribe软件,打开要添加中文字体的位置。打开Photoshop并在文件中创建一个新的透明背景图层。注意:必须是透明背景层。...

五个流行的SVG在线编辑器(svg编辑工具)

随着响应网络的发展,越来越多的高质量的SVG在线编辑器被公众所熟知。SVG矢量图形也越来越受欢迎,以便在任何设备上呈现图像,甚至一些易于使用的SVG在线编辑器,可以替代PS,本文总结了五种流行的SVG...