当前位置:   article > 正文

让所有GUI都自动化-PyAutoGUI(GUI自动化工具)

pyautogui

目录

1、前言

2、简介

3、安装

4、常用函数

5、保护措施

6、鼠标函数

7、键盘函数

8、消息弹窗函数

9、截屏函数

‍10、示例


1、前言

在使用 Selenium 进行自动化测试时,鼠标事件可以用 ActionChains 类,键盘事件可以用 Keys 类。本篇将介绍一款自动化工具-PyAutoGUI,除了可以满足鼠标、键盘事件操作外,还可以进行消息弹窗、截屏等操作。

2、简介

PyAutoGUI 是一个纯 Python 的 GUI 自动化工具,其目的是可以用程序自动控制鼠标和键盘操作,多平台支持(Windows,macOS,Linux),并在 Python 2 和 3 上运行。

PyAutoGUI 可以模拟鼠标的移动、点击、拖拽,键盘按键输入、按住操作,以及鼠标+键盘的热键同时按住等操作,可以说手能动的都可以。

PyAutoGUI 有几个特点:

1、移动鼠标并单击其他应用程序的窗口。

2、向应用程序发送点击输入(例如,填写表格)。

3、截取屏幕截图,并给出一个图像(例如,一个按钮或复选框),然后在屏幕上找到它。

4、找到应用程序的窗口,然后移动、调整大小、最大化、最小化或关闭它(目前仅限 Windows)。

5、显示警报和消息框。

Github地址:

https://github.com/asweigart/pyautogui

3、安装

1、Windows 环境下

PyAutoGUI 没有任何依赖,因为它用 Python 的 ctypes 模块,所以不需要 pywin32。

pip3 install pyautogui

2、macOS 环境下

PyAutoGUI 需要 PyObjC 运行 AppKit 和 Quartz 模块。

  1. sudo pip3 install pyobjc-core
  2. sudo pip3 install pyobjc
  3. sudo pip3 install pyautogui

3、Linux 环境下

PyAutoGUI 需要 python-xlib(Python 2)、python3-Xlib(Python 3)

  1. sudo pip3 install python3-xlib
  2. sudo apt-get scrot
  3. sudo apt-get install python-tk
  4. sudo apt-get install python3-dev
  5. sudo pip3 install pyautogui

4、常用函数

position():返回整数元组 (x, y),分别表示鼠标光标所在位置的 XY 轴坐标。

size():返回显示器的尺寸整数元组 (x, y)。

onScreen():要检查 XY 坐标是否在屏幕上,需要用此函数来检验,如果在屏幕上返回 True,否则返回 False。

1、获取当前鼠标的坐标

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. print(pyautogui.position())

运行结果:

2、获取当前屏幕的分辨率(宽度和高度)

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. print(pyautogui.size())

运行结果:

3、判断坐标是否在屏幕上

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. x, y = 500600
  6. print(pyautogui.onScreen(x, y))

运行结果:

5、保护措施

PAUSE 方法可以进行增加延迟时间,例如 3.5 秒。

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.PAUSE = 3.5

6、鼠标函数

屏幕位置使用 X 和 Y 轴的笛卡尔坐标系。

原点 (0,0) 在左上角,分别向右、向下增大。

如果屏幕像素是 1920*1080,那么右下角的坐标是 (1919, 1079)。

moveTo():函数会把鼠标光标移动到指定的 XY 轴坐标处。如果传入 None 值,则表示使用当前光标的对象轴坐标值。

moveRel():如果你想让光标以当前位置为原点,进行相对移动,就用此函数。

dragTo() 和 dragRel():函数与 moveTo() 和 moveRel() 函数类似。另外,他们有一个 button 参数可以设置成 left,middle 和 right 三个键。

click():函数模拟单击鼠标左键一次的行为。参数可以设置,其中,button 属性可以设置成 left,middle 和 right。

doubleClick(),tripleClick() 和 rightClick():函数来实现双击、三击和右击操作。

mouseDown() 和 mouseUp():函数可以实现鼠标按下和鼠标松开的操作。两者参数相同,有 x,y 和 button。

scroll():函数控制鼠标滚轮的滚动,amount_to_scroll 参数表示滚动的格数。正数则页面向上滚动,负数则向下滚动。

1、鼠标移动

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. num_seconds = 1.2
  6. # 用num_seconds秒的时间把光标移动到(x, y)位置
  7. pyautogui.moveTo(x, y, duration=num_seconds)
  8. # 用num_seconds秒的时间把光标的
  9. # X轴(水平)坐标移动xOffset,
  10. # Y轴(竖直)坐标向下移动yOffset。
  11. xOffset, yOffset = 50100
  12. pyautogui.moveRel(xOffset, yOffset, duration=num_seconds)

2、鼠标移动(缓动/渐变)- 改变光标移动过程的速度和方向。通常鼠标是匀速直线运动的。

  1. # 开始很慢,不断加速
  2. pyautogui.moveTo(1001002, pyautogui.easeInQuad)
  3. # 开始很快,不断减速
  4. pyautogui.moveTo(1001002, pyautogui.easeOutQuad)
  5. # 开始和结束都快,中间比较慢
  6. pyautogui.moveTo(1001002, pyautogui.easeInOutQuad)
  7. # 一步一徘徊前进
  8. pyautogui.moveTo(1001002, pyautogui.easeInBounce)
  9. # 徘徊幅度更大,甚至超过起点和终点
  10. pyautogui.moveTo(1001002, pyautogui.easeInElastic)

3、鼠标拖拽

  1. # 按住鼠标左键,把鼠标拖拽到(100, 200)位置
  2. pyautogui.dragTo(100200, button='left')
  3. # 按住鼠标左键,用2秒钟把鼠标拖拽到(300, 400)位置
  4. pyautogui.dragTo(3004002, button='left')
  5. # 按住鼠标右键,用2秒钟把鼠标拖拽到(30,0)位置
  6. pyautogui.dragTo(3002, button='right')

4、鼠标点击

  1. # 先移动到(100, 200)再单击
  2. pyautogui.click(x=100, y=200, duration=2)
  3. # 右键
  4. pyautogui.click(button='right')
  5. # 双击左键
  6. pyautogui.click(clicks=2)
  7. # 两次单击之间停留0.25
  8. pyautogui.click(clicks=2, interval=0.25)
  9. # 三击右键
  10. pyautogui.click(button='right', clicks=2, interval=0.25)

5、鼠标按下和鼠标松开

  1. # 鼠标左键按下再松开
  2. pyautogui.mouseDown(); pyautogui.mouseUp()
  3. # 按下鼠标右键
  4. pyautogui.mouseDown(button='right')
  5. # 移动到(100, 200)位置,然后松开鼠标右键
  6. pyautogui.mouseUp(button='right', x=100, y=200)

6、鼠标滚动

  1. # 向上滚动10
  2. pyautogui.scroll(10)
  3. # 向下滚动10
  4. pyautogui.scroll(-10)
  5. # 移动到(100, 100)位置再向上滚动10
  6. pyautogui.scroll(10, x=100, y=100)

7、键盘函数

typewrite():函数可以实现字符输入。要在两次输入间增加时间间隔,可以用 interval 参数。此函数只能用于单个字符键,不能按 SHITF 和 F1 这些功能键。

KEYBOARD_KEYS:获取按键名称。

press():函数把 pyautogui.KEYBOARD_KEYS 里面按键对应的字符串输入进去。

hotkey():函数来绑定若干键盘热键。像 Ctrl-S 或 Ctrl-Shift-1 都可以用此函数来实现。

1、键盘输入

  1. # 输入Hello world!
  2. pyautogui.typewrite('Hello world!')
  3. # 每次输入间隔0.25秒,输入Hello world!
  4. pyautogui.typewrite('Hello world!', interval=0.25)
  5. # 多个键也可以
  6. pyautogui.typewrite(['a''b''c''left''backspace''enter''f1'], interval=0.5)

2、按键名称

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. print(pyautogui.KEYBOARD_KEYS)

运行结果:

3、键盘按键

  1. # ENTER键
  2. pyautogui.press('enter')
  3. # F1键
  4. pyautogui.press('f1')
  5. # 左方向键
  6. pyautogui.press('left')
  7. # 用数组把一组键传入
  8. pyautogui.press(['left''left''left'])

press() 函数其实是 keyDown() 和 keyUp() 函数的包装,模拟的按下然后松开两个动作。这两个函数可以单独调用。

例如,按下 shift 键的同时按3次左方向键。每个按键的按下和松开也可以单独调用。

  1. # 按下`shift`键
  2. pyautogui.keyDown('shift')
  3. pyautogui.press('left')
  4. pyautogui.press('left')
  5. pyautogui.press('left')
  6. # 松开`shift`键
  7. pyautogui.keyUp('shift')

4、键盘热键

  1. pyautogui.hotkey('ctrl''a'# 全选
  2. pyautogui.hotkey('ctrl''c'# 复制
  3. pyautogui.hotkey('ctrl''v'# 粘贴

8、消息弹窗函数

如果你需要消息弹窗,通过单击 OK 暂停程序,或者向用户显示一些信息,消息弹窗函数就会有类似JavaScript 的功能。

alert():函数显示一个简单的带文字和 OK 按钮的消息弹窗。用户点击后返回 button 的文字。

confirm():函数显示一个简单的带文字、OK 和 Cancel 按钮的消息弹窗,用户点击后返回被点击 button 的文字,支持自定义数字、文字的列表。

prompt():函数可以输入的消息弹窗,带 OK 和 Cancel 按钮。用户点击 OK 按钮返回输入的文字,点击 Cancel 按钮返回 None。

password():函数样式同 prompt(),用于输入密码,消息用 * 表示。带 OK 和 Cancel 按钮。用户点击 OK 按钮返回输入的文字,点击 Cancel 按钮返回 None。

1、alert() 函数

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.alert(text='点击OK按钮', title='alert()函数', button='OK')

运行结果:

2、confirm() 函数

(1)OK 和 Cancel 按钮的消息弹窗

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.confirm(text='点击OK或Cancel按钮', title='confirm()函数', buttons=['OK''Cancel'])

运行结果:

(2)10 个按键 0-9 的消息弹窗

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.confirm(text='点击0到9按钮', title='confirm()函数', buttons=range(10))

运行结果:

3、prompt() 函数

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.prompt(text='输入消息弹窗', title='prompt()函数', default='用户点击OK')

运行结果:

4、password() 函数

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. pyautogui.password(text='输入消息弹窗', title='password()函数', default='用户点击OK', mask='*')

运行结果:

9、截屏函数

PyAutoGUI 用 Pillow/PIL 库实现图片相关的识别和操作。

在 Linux 里面,你必须执行 sudo apt-get install scrot 来使用截屏特性。

1、截屏

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import pyautogui
  5. # 返回一个Pillow/PIL的Image对象
  6. pyautogui.screenshot()
  7. pyautogui.screenshot('Desktop.png')

运行结果:

如果你不需要截取整个屏幕,还有一个可选的 region 参数。你可以把截取区域的左上角 XY 坐标值和宽度、高度传入截取。

im = pyautogui.screenshot(region=(0,0,300,400))

2、如果你有一个图片文件想在上面做点击操作,你可以用 locateOnScreen() 函数来定位。

  1. # 返回(最左x坐标,最顶y坐标,宽度,高度)
  2. pyautogui.locateOnScreen('pyautogui/looks.png')

3、locateAllOnScreen() 函数会寻找所有相似图片,返回一个生成器。

  1. for i in pyautogui.locateAllOnScreen('pyautogui/looks.png'):
  2.     print(i)

list(pyautogui.locateAllOnScreen('pyautogui/looks.png'))

4、locateCenterOnScreen() 函数会返回图片在屏幕上的中心 XY 轴坐标值。

pyautogui.locateCenterOnScreen('pyautogui/looks.png')

‍10、示例

使用 Selenium 打开 Chrome 浏览器,访问百度首页,输入关键字进行查询,之后向下滚动后再进行截屏的一系列操作。

由于 PyAutoGUI 不支持中文输入,这里使用 pyperclip 库,采用“复制粘贴”的方式来输入中文。

注:由于作者是 macOS 环境下运行,ctrl+v 粘贴则是 command+v。

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # 公众号:AllTests软件测试
  4. import time
  5. import pyperclip
  6. import pyautogui
  7. from selenium import webdriver
  8. from selenium.webdriver.common.by import By
  9. class TestMyTest():
  10.     def setup_method(self):
  11.         self.driver = webdriver.Chrome()
  12.         self.pyautogui = pyautogui
  13.         self.pyperclip = pyperclip
  14.     def teardown_method(self):
  15.         self.driver.quit()
  16.     def test_myTest(self):
  17.         self.driver.get("https://www.baidu.com/")
  18.         time.sleep(2)
  19.         self.pyautogui.typewrite('pyautogui', interval=0.25)
  20.         time.sleep(2)
  21.         self.pyperclip.copy("自动化测试")
  22.         time.sleep(2)
  23.         self.pyautogui.hotkey('command''v')
  24.         time.sleep(2)
  25.         self.driver.find_element(By.ID, "su").click()
  26.         time.sleep(2)
  27.         self.pyautogui.scroll(-10)
  28.         time.sleep(2)
  29.         self.pyautogui.screenshot('Desktop.png')

精彩推荐

面试笔试系列

思维导图系列

Linux常用命令壁纸

接口Requests系列

测试框架pytest系列

Jmeter快速上手之接口测试

自动化测试框架结构图

移动安全框架(MobSF)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/93107
推荐阅读
相关标签
  

闽ICP备14008679号