PC自动化之pywinauto
官方文档: https://pywinauto.readthedocs.io/en/latest/contents.html
[安装]
pip install pywinauto
[使用]
from pywinauto import application # 创建应用程序对象并打开应用程序
app = application.Application()
app.start('your_application.exe') # 连接到应用程序窗口
app.connect(title='Window Title') # 获取窗口对象
window = app.window(title='Window Title') # 获取子控件
child = window.child_window(class_name='UIAutomationClassName') # 获取子控件的UI元素信息
element_info = child.uia_element_info # 打印UI元素信息
print(element_info)
1.其中的点击事件,需要使用click_input代替click(无法正常使用)
2.其中涉及的鼠标和键盘的相关事件,推荐使用单独包
from pywinauto import mouse, keyboard
3.元素的操作对象是一个dialog, 所以应用需要指定
app.window(title='', class_name='')
可以指定名称或类名称
4.查找元素
win.child_window(title='', control_type='',found_index=0)
注: 如果存在多个元素, 则可以通过索引指定:found_index
指定名称和控件类型
常见控件类型:
Window: 窗口
ToolBar: 导航
Button: 按钮
ListItem: 聊天列表
Text:聊天内容
5.查询所有Windows下的窗口元素
# 查询当前内置浏览器窗格信息
wins = pywinauto.findwindows.find_elements(backend='uia')
print('所有窗口:', wins)
# 查找指定窗口的进程,类名,窗口名称(任务栏中展示的名称)等情况
pid = 0
for win in wins:
print('=======================')
print(dir(win))
print(win.name) # 窗口名称
# print(win.control_id) # 都是0
# print(win.process_id)
# print(win.automation_id)
print(win.class_name) # 类名
# print(win.control_id) # 都是0
print(win.runtime_id) # (id, 进程ID)
if win.class_name == 'Chrome_WidgetWin_0':
pid = win.runtime_id[1]
# 使用handle的方式链接窗口并执行操作
app2 = Application(backend='uia').connect(handle=pid)
# print(app2.window().print_control_identifiers()) app2.window().child_window(title='关闭', control_type='Button', found_index=0).click_input()
使用实例:
1)自动打开微信链接
import random
import time from pywinauto import mouse, keyboard
import pywinauto.findwindows
from pywinauto.application import Application
import pyautogui # 连接方式1)
# app = Application(backend='uia').connect(process=19004) # 连接方式2)
app = Application(backend='uia').connect(path=r'D:\software\WeChat\WeChat.exe') # 该窗口中的对话框, 方便查看当前的窗口或窗格情况
# print(app.windows())
# Chrome_WidgetWin_0 # 打开
# app = Application(backend='uia').start('D:\software\WeChat\WeChat.exe')
# time.sleep(5)
# 拿到微信主窗口
win_main_dialog = app.window(title='微信', class_name='WeChatMainWndForPC') # 判断是否未dialog, 一个微信就是一个dialog -->窗口
# print(win_main_dialog.is_dialog) # print(win_main_dialog.wrapper_object()) # 给空间画一个红色框便于看出
win_main_dialog.draw_outline(colour='red') # 打印当前所有空间和属性
# win_main_dialog.print_control_identifiers(depth=None, filename=None) time.sleep(1) def get_element_position(ele):
"""获取元素的中心点位置"""
element_position = ele.rectangle()
# 算出中心点位置
center_position = (int((element_position.left + element_position.right) / 2),
int((element_position.top + element_position.bottom) / 2))
return center_position def send_msg():
# 找到文件传输助手
file_helper_ele = win_main_dialog.child_window(title="文件传输助手已置顶", control_type="ListItem")
mouse.click(button='left', coords=get_element_position(file_helper_ele)) # 获取输入框元素, 并模拟输入
edit_ele = win_main_dialog.child_window(title="文件传输助手", control_type="Edit")
time.sleep(2)
edit_ele.type_keys("hello")
keyboard.send_keys("{ENTER}") def click_buttons():
'''分别进行点击'''
win_main_dialog.child_window(title="聊天", control_type="Button").click_input()
time.sleep(2)
win_main_dialog.child_window(title="通讯录", control_type="Button").click_input()
time.sleep(2)
win_main_dialog.child_window(title="朋友圈", control_type="Button").click_input()
time.sleep(2) def gui():
# 使用pyautogui方式是比较固定(坐标)的方式
pyautogui.click(x=622, y=183, clicks=1, interval=0.1)
time.sleep(random.randint(3, 5))
pyautogui.click(x=756, y=78, clicks=1, interval=0.1) '''
depth: 打印深度, 缺省最大深度
filenmae: 返回的标识存成文件, 可以指定 eg:a.txt
''' # 查找主窗口下的某个窗口
# chat_list = win_main_dialog.child_window(control_type='List', title='会话')
# first = chat_list.items()[0] # 第一个聊天项, 支持循环, 索引
# chat_list.scroll(direction='down', amount='page') # 向下滚动一页 # first.focus() def main():
# 找到聊天框
chat_list_ele = win_main_dialog.child_window(title="聊天", control_type="Button")
mouse.click(button='left', coords=get_element_position(chat_list_ele))
time.sleep(1)
# 找到指定聊天人
ln = win_main_dialog.child_window(title="Learning已置顶", control_type="ListItem")
mouse.click(button='left', coords=get_element_position(ln)) time.sleep(1)
# 找到指定链接并点击
lk = win_main_dialog.child_window(title=r"https://www.cnblogs.com/xingxia", control_type="ListItem")
mouse.click(button='left', coords=get_element_position(lk)) time.sleep(random.randint(3, 5))
# 关闭内置浏览器 # 1) 查询当前内置浏览器窗格信息
wins = pywinauto.findwindows.find_elements(backend='uia')
print('所有窗口:', wins)
pid = 0
for win in wins:
print('=======================')
print(dir(win))
print(win.name) # 窗口名称
# print(win.control_id) # 都是0
# print(win.process_id)
# print(win.automation_id)
print(win.class_name) # 类名
# print(win.control_id) # 都是0
print(win.runtime_id) # (id, 进程ID)
if win.class_name == 'Chrome_WidgetWin_0':
pid = win.runtime_id[1] app2 = Application(backend='uia').connect(handle=pid)
# print(app2.window().print_control_identifiers()) app2.window().child_window(title='关闭', control_type='Button', found_index=0).click_input() if __name__ == '__main__':
main() # 自动化主流程
# send_msg() # 发送消息
# click_buttons()
# gui()
说明:
1.其中元素定位软件需要借助: inspect.exe 或者 UISpy
PC端的自动化, 除了可以使用pywinauto之外,还有其他的工具可以选择, 例如:uiautomation
对比PyWinAuto和uiautomation
PyWinAuto和uiautomation都是自动化测试工具,它们都可以模拟用户的操作来测试应用程序的功能。但是PyWinAuto是一个Python库,可以跨平台使用,而uiautomation是一个Windows平台的测试工具。除此之外,PyWinAuto提供更多的GUI操作函数和更好的文档支持,而uiautomation则更加适合对Windows应用程序进行测试。
安装
pip install uiautomation
github: https://github.com/yinkaisheng/Python-UIAutomation-for-Windows
PC自动化之pywinauto的更多相关文章
- Windows GUI程序自动化之pywinauto
一. pywinauto知识点总结 官方英文版文档网址:https://pywinauto.readthedocs.io/en/latest/index.html 1.1 pywinauto的安装与配 ...
- eclipse 集成jdk
最近想整合一个工具,eplise中包含了 pc 自动化可用的一套环境,让其他测试人员,下载下来就可以用,不需要在进行安装其他东西,jdk安装也不需要,这事可有些犯难,eplise集成了svn和test ...
- airtest+poco多脚本、多设备批处理运行测试用例自动生成测试报告
一:主要内容 框架功能及测试报告效果 airtest安装.环境搭建 框架搭建.框架运行说明 airtest自动化脚本编写注意事项 二:框架功能及测试报告效果 1. 框架功能: 该框架笔者用来作为公司的 ...
- Python+Selenium - 文件上传
如下图,从系统点击上传功能,打开到这种如下图页面的才适合本文介绍的处理方法 处理方法一 pywinauto库 优点:可以选择多个文件,路径中有中文也支持 缺点:只能Windows平台使用 安装 pip ...
- python 实现 PC 客户端自动化快速入门:pywinauto !
本文转载自:http://www.lemfix.com/topics/420 一.前言 我们柠檬班的小可爱,在学完我们柠檬班自动化的课程之后,就掌握了接口自动化,web自动化,app自动化,这些工 ...
- 聊聊 PC 端自动化最佳方案 - Pywinauto
1. 前言 大家好,我是安果! 上一篇文章,聊到 PC 端的一种自动化方案:WinAppDriver 聊聊 PC 端自动化最佳方案 - WinAppDriver 有小伙伴后台给我留言,说「 pywin ...
- Pywinauto自动化操作PC微信提取好友微信号
声明:https://zhuanlan.zhihu.com/p/29944988#! /usr/bin/env python #coding=utf-8 #pywinauto自动化操作微信号 #by ...
- python+pywinauto之PC端自动化一
所需软件安装: 1.下载 pywinauto 安装参考: https://jingyan.baidu.com/article/414eccf6a1a3906b421f0a59.html 下载地址: h ...
- pywinauto之PC端windows自动化测试
pywinauto是一个用纯Python编写的GUI自动化库,并为Windows GUI精心开发.最简单的是,它允许您将鼠标和键盘操作发送到Windows和Linux上的对话框和控件,而到目前为止,仅 ...
- Macaca自动化测试之PC端测试
Macaca是一套完整的自动化测试解决方案.由阿里巴巴公司开源: http://macacajs.github.io/macaca/ 特点: 同时支持PC端和移动端(Android.iOS)自动化测试 ...
随机推荐
- Java基础12
抽象类与抽象方法 abstract : 抽象的 abstract可以用来修饰:类.方法 abstract修饰类 > 此类称为抽象类 > 抽象类不能实例化 > 抽象类中是包含构造器的, ...
- python操作ipv6_用python开启临时http服务器及其ipv6支持
https://blog.csdn.net/weixin_35647799/article/details/112023159
- JavaScript 中 structuredClone 和 JSON.parse(JSON.stringify()) 克隆对象的区别
JavaScript 中 structuredClone 和 JSON.parse(JSON.stringify()) 克隆对象的异同点 一.什么是 structuredClone? 1. struc ...
- Python存储与读写二进制文件
技术背景 一般情况下我们会选择使用明文形式来存储数据,如json.txt.csv等等.如果是需要压缩率较高的存储格式,还可以选择使用hdf5或者npz等格式.还有一种比较紧凑的数据存储格式,就是直接按 ...
- Goby漏洞发布 | 0day NACOS /nacos/v1/cs/ops/data/removal RCE代码执行漏洞【已验证】
漏洞名称:NACOS /nacos/v1/cs/ops/data/removal RCE代码执行漏洞 English Name:NACOS /nacos/v1/cs/ops/data/removal ...
- 以太坊Rollup方案之 arbitrum(2)
上一期简单介绍了一下rollup的一些基本内容以及aritrun交易的执行流程,这一期将介绍一下aritrum的核心技术 -- 交互式单步证明 这一期主要涉及到的是arbitrum的验证节点 arbi ...
- 手搓大模型Task03:手搓一个最小的 Agent 系统
前言 训练一个大模型是一件高投入低回报的事情,况且训练的事情是由大的巨头公司来做的事情:通常我们是在已有的大模型基础之上做微调或Agent等:大模型的能力是毋庸置疑的,但大模型在一些实时的问题上, ...
- linux内核调试痛点之函数参数抓捕记
1.linux内核调试工具crash并不能直接显示函数参数,而这个对调试又非常重要 下面是工作中一个实际的问题,我们的进程hang在如下一个内核栈中了,通过栈回溯可知是打开了一个nfs3的网盘文件或者 ...
- [快速阅读八] HDR->LDR:Matlab中tonemapfarbman函数的解析和自我实现。
最近受朋友的委托,想自己实现Matlab里的一个HDR转LDR的函数,函数名是tonemapfarbman,乘着十一假期,稍微浏览下这个函数,并做了一点C++的实现和优化. 为了看到这个函数的效果,需 ...
- 深度学习 - Torch-TensorRT 推理加速
深度学习 - Torch-TensorRT 推理加速 Torch-TensorRT 作为 TorchScript 的扩展. 它优化并执行兼容的子图,让 PyTorch 执行剩余的图. PyTorch ...