目录
GUI控制神器
鼠标操作
鼠标信息
鼠标移动
鼠标点击
鼠标点击与释放
鼠标拖动
鼠标滚动
键盘操作
键盘控制
特殊符号
快捷键
屏幕处理
获取屏幕截屏
信息框
自动点赞实战
首页 后端开发 Python教程 完全掌握Python自动操作GUI之PyAutoGUI

完全掌握Python自动操作GUI之PyAutoGUI

Jul 06, 2022 pm 01:53 PM
python

本篇文章给大家带来了关于Python的相关知识,其中主要整理了自动操作GUI之PyAutoGUI的相关问题,桌面自动化操作是通过定位鼠标在桌面的位置,然后根据定位的位置执行对应的操作,下面一起来看一下,希望对大家有帮助。

完全掌握Python自动操作GUI之PyAutoGUI

【相关推荐:Python3视频教程

GUI控制神器

我们今天的主人公是 pyautoguipyautogui 是一个纯 Python 的 GUI 自动化工具,通过它可以让程序自动控制鼠标和键盘的一系列操作来达到自动化测试的目的。

模块安装,打开cmd,输入:

1

pip install pyautogui

登录后复制

成功展示:
Successfully installed PyTweening-1.0.4 mouseinfo-0.1.3 pyautogui-0.9.53 pygetwindow-0.0.9 pymsgbox-1.0.9 pyperclip-1.8.2 pyrect-0.2.0 pyscreeze-0.1.28

安装好后就可以直接使用了。

导包

1

import pyautogui

登录后复制

鼠标操作

鼠标信息

  • pyautogui.position() 获取鼠标位置
  • pyautogui.onScreen(x,y) 判断坐标(x,y)是否在屏幕内,返回True,Flase
    以右上角为(0,0)点

鼠标移动

桌面操作最基本的就是鼠标操作了,我们可以控制鼠标的移动:

  • pyautogui.moveTo(x,y) 绝对位置移动 ,移动到x,y
  • pyautogui.moveRel(x,y) 相对位置移动 ,从当前位置移动

1

2

3

# 移动鼠标

pyautogui.moveTo(200,400,duration=2)

pyautogui.moveRel(200,500,duration=2)

登录后复制

整个桌面是以左上角为坐标轴的原点,所有的操作都以这个原点,来确定操作位置。

第一行是将鼠标移动到指定的像素(200,400)位置;
第二行代码是将鼠标按照当前点向右移动200px,向下移动500px这个方向移动。

两行代码中都有一个共同的参数 duration,这个参数表示移动时间,即在指定时间内完成移动操作,单位是

运行这两行代码,观察屏幕鼠标的变化,是不是很神奇?

鼠标点击

通常,我们的鼠标有左右两个按键,高级点的鼠标中间还有个按键。

我的鼠标只有两个按键,中间没有按键,唉~
pyautogui针对这三个按键操作都有相应的处理:

  • pyautogui.click()
    (100,100, clicks=2,interval=0.5,button=‘right’,duration=0.2)
    位置,点击次数,间隔时间,右键(默认左键),移动间隔
  • left:左键 right:右键 middle:中键

1

2

3

4

5

6

7

8

# 鼠标点击,默认左键

pyautogui.click(100,100)   

# 单击左键

pyautogui.click(100,100,button='left')  

# 单击右键

pyautogui.click(100,300,button='right'

# 单击中间 

pyautogui.click(100,300,button='middle')

登录后复制

鼠标点击,如果不指定 button 参数,默认是点击左键,前面两个参数就是点击坐标的位置。

运行这段代码,看看你的桌面会发生什么?

鼠标除了点击操作,还有双击操作:

  • pyautogui.doubleClick() #双击右键
  • pyautogui.leftClick() #双击左键
  • pyautogui.middleClick() #双击中键
  • pyautogui.tripleClick() #双击屏幕

1

2

3

4

5

6

7

8

# 双击左键

pyautogui.doubleClick(10,10)  

# 双击右键

pyautogui.rightClick(10,10)   

# 双击中键

pyautogui.middleClick(10,10) 

# 双击屏幕

pyautogui.tripleClick(10,10)

登录后复制

操作函数也很简单,相信大家一眼就能看明白,如果一眼看不明白,请多看几眼!

熟悉前端的小伙伴可能会马上联想到,鼠标操作有按下和释放的过程,我们屏幕操作也有对应的控制:

鼠标点击与释放

  • pyautogui.mouseUp() #释放
  • pyautogui.mouseDown() #点击 只需要输入键就可

1

2

3

4

# 鼠标按下

pyautogui.mouseDown()   

# 鼠标释放

pyautogui.mouseUp()

登录后复制

鼠标拖动

  • pyautogui.dragTo() #绝对位置拖动
  • pyautogui.dragRel() #相对位置拖动
    例:pyautogui.dragRel(-100,200,duration=0.5,button=‘right’)

我们可以控制鼠标拖动到指定坐标位置,并且设置操作时间和按键:

1

pyautogui.dragTo(100,300,duration=1,button='right')

登录后复制

这个运行效果和前面移动类似。

根据前面移动的经验,我们也有按照方向拖动鼠标:

1

pyautogui.dragRel(100,300,duration=4,button='left')

登录后复制

鼠标滚动

在桌面操作中,我们有时候需要滚动鼠标到达向上或者向下的位置,这时候我们可以使用 scroll 这个函数来控制:

  • pyautogui.scroll() #(,x,y) 滑动距离(+上 , -下),位置

1

pyautogui.scroll(30000)

登录后复制

参数是整数,表示向上或向下滚动多少个单位,这个单位根据不同的操作系统可能不一样。如果向上滚动,传入正整数,向下滚动传入负整数。

键盘操作

键盘控制

  • pyautogui.keyDown() #模拟按键放下,内容为按键符
  • pyautogui.keyUp() #模拟按键松开
  • pyautogui.press() #模拟一次按键过程,即keyDown和keyUP的组合
  • pyautogui.hotkey() #press一样 区别:可以组合按键
  • pyautogui.typewrite() #模拟键盘输出内容

举个例子,大家平时输入感叹号(!)是怎么操作键盘的?

按住 shift 按键,然后再按住 1 按键,就可以了。用pyautogui控制就是:

1

2

3

pyautogui.keyDown('shift')    

pyautogui.press('1')    

pyautogui.keyUp('shift')

登录后复制

运行上面的代码,如果你的鼠标是放在编辑框中,你会得到一个感叹号!

我们还可以直接输出内容:

1

pyautogui.typewrite('python', 1)

登录后复制

第一个参数是输出的内容,第二个参数是间隔时间,单位是秒。

运行上面代码,你的编辑器里面就会每隔1秒钟按顺序输出 python 的6个字母。

特殊符号

有时我们需要输入键盘的一些特殊的符号按键,比如 换行、方向键等,这些有相对应的键盘字符串表示:

1

2

pyautogui.typewrite(['p','y','t','h','o','n','enter'])   

pyautogui.typewrite(['p','y','t','h','o','n',' '])

登录后复制

运行上面代码,编辑器里面就会输出 python 之后换行。

其他特殊按键对应的字符串请参考官方说明。

快捷键

如果我要复制一个内容,大部分情况下会使用快键键 ctrl + c,按照上面讲的,我们应该这么实现:

1

2

3

4

pyautogui.keyDown('ctrl')

pyautogui.keyDown('c')

pyautogui.keyUp('c')

pyautogui.keyUp('ctrl')

登录后复制

实现的效果和上面的4行代码相同。

键盘字符串 说明
enter(或return 或 \n) 回车
esc ESC键
shiftleft, shiftright 左右SHIFT键
altleft, altright 左右ALT键
ctrlleft, ctrlright 左右CTRL键
tab (\t) TAB键
backspace, delete BACKSPACE 、DELETE键
pageup, pagedown PAGE UP 和 PAGE DOWN键
home, end HOME 和 END键
up, down, left,right 箭头键
f1, f2, f3…. f12 F1…….F12键
volumemute, volumedown,volumeup 声音变大变小静音(有些键盘没有)
pause PAUSE键,暂停键
capslock CAPS LOCK 键
numlock NUM LOCK 键
scrolllock SCROLLLOCK 键
insert INSERT键
printscreen PRINT SCREEN键
winleft, winright Win键(windows )
command command键(Mac OS X )
option option(Mac OS X)

屏幕处理

获取屏幕截屏

我们先来假设一个场景:我现在要在屏幕上找到一个红色的点,你会怎么做?通常的做法是拿到这个红色点的颜色值,然后再对屏幕上的点逐个进行比较,直到找到为止。

pyautogui 为我们这个操作场景提供了支持,分别有三个函数可以完成这三件事情。

  • img = pyautogui.screenshot() #默认是全屏,可是输入截屏大小
  • img.save(‘img.jpg’)
  • pyautogui.screenshot(‘image’,region=(x,y,w,h) # 返回屏幕的截图,是一个Pillow的image对象
  • pyautogui.pixelMatchesColor(500,500,(12,120,400)) # 是一个对比函数,对比的是屏幕上(500,500)这一点像素的颜色,与所给的元素是否相同;
  • pyautogui.locateCenterOnScreen(‘image’, region=(x,y,w,h) ) #图片匹配功能,查找image图片在屏幕中的位置,region限制查找范围

1

2

3

4

5

6

im = pyautogui.screenshot()

im.save('screenshot.png')

rgb = im.getpixel((100, 500))

print(rgb)

match = pyautogui.pixelMatchesColor(500,500,(12,120,400))

print(match)

登录后复制

第一个是获取屏幕截图函数,它可以返回一个 Pillow 的 image 对象; 第二个是获取屏幕截图中指定坐标点的颜色,返回 rgb 颜色值;第三个是将指定坐标点的颜色和目标的颜色进行比对,返回布尔值。

我们再来升级一下需求:

我现在要在屏幕上找到 edge 浏览器的图标,你会怎么做?

通常的做法是先知道 edge 浏览器的图标长啥样,是绿色还是蓝色,是胖的还是瘦的,对吧?然后再在屏幕上去进行图标的匹配,直到找到一个图标跟我们目标图标一样,就得到了结果。

于是,我们的代码如下:

1

2

3

4

5

6

7

# 图像识别(一个)

oneLocation = pyautogui.locateOnScreen('1.png')

print(oneLocation)  

 

# 图像识别(多个)

allLocation = pyautogui.locateAllOnScreen('1.png')

print(list(allLocation))

登录后复制

你可以在桌面上将某个应用的图标截取下来,保存为图片,然后使用上面几行代码来识别,识别成功,你会返回类似下面的结果:

1

2

Box(left=20, top=89, width=33, height=34)

[Box(left=20, top=89, width=33, height=34)]

登录后复制

这就是图片在桌面的位置,如果找不到图片,就会返回 None。

信息框

当你在模拟一个桌面操作的时候,如果有分支操作需要根据实际情况来判断,你是不是需要有一个地方可以让你选择走哪个分支?

pyautogui 贴心地考虑到了这种情况,你可以通过弹出一个选择框来中断当前的操作,选择操作分支。

  • pyautogui.alert(text=,title=,button=) #按钮框 文本,标题,按钮名
  • pyautogui.confirm(text=,title=,buttons=) #组合按钮框(多个按钮)
  • pyautogui.prompt(text=,title=,default=) #输入框 #文本,标题,默认文字
  • pyautogui.password(text=,title=,default=,mask=) #密码输入框 #输入框 #文本,标题,默认文字,掩码样式
  • pyautogui.mouseInfo() #获取鼠标的信息

1

2

way = pyautogui.confirm('领导,该走哪条路?', buttons=['农村路''水路''陆路'])

print(way)

登录后复制

这里就是我们 HTML 页面的 confirm 选择框,选择了选项之后,我们可以获取到选择的选项,然后基于这个选项做判断,进入相应的操作分支。

除了选择确认框之外,还有其他一些提示信息框:

1

2

3

4

5

6

7

8

9

# 警告框

alert = pyautogui.alert(text='警告!敌军来袭!', title='警告框')

print(alert)

# 密码框

password = pyautogui.password('请输入密码')

print(password)

# 普通输入框

input = pyautogui.prompt('请输入指令:')

print(input)

登录后复制

pyautogui 的基本知识就给大家介绍到这里,这个 python 模块的功能十分强大,函数都非常简单,对 python 初学者比较友好。学了这些基本知识之后,你可以运用这些基本知识的组合,去实现一些有趣的桌面自动化操作,快去尝试一把吧!

自动点赞实战

我们通过今天的基础知识的学习,我们可以通过pyautogui+PIL结合来实现网页自动点赞的实战练习。

我们先介绍一个PIL库下一个裁剪图片的函数crop。

使用PIL裁切图片使用PIL需要引用Image,使用Image的open(file)方法可以返回打开的图片,使用crop((x1,y1,x2,y2))方法可以对图片做裁切。
该区域是一个元组,(x1,y1)是图片左上角的坐标,(x2,y2)是图片右下角的坐标。
Python Imaging Library 使用左上角为 (0, 0)的坐标系统。
在这里插入图片描述

首先我们要知道点赞的图片的样子

1

2

3

4

5

6

# 截取整个屏幕

im=pyautogui.screenshot()

# 截取点赞图片

om=im.crop((1754,595,1803,631)) 

#将图片保存供pyautogui.locateOnScreen()使用

om.save("dianzan.png")

登录后复制

根据截取的屏幕仅截取带赞的手势图片,可以用pyautogui.mouseInfo()获取图片的位置(1754,595,1803,631)
或者通过pyautogui.location()来确定首尾坐标

在当前目录下得到如下图片。
在这里插入图片描述

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

# 点赞函数

def zan(count): #为了防止一直运行下去,点赞次数由自己定义

    time.sleep(0.5)

    # 寻找刚才保存点赞手势图片

    xy = pyautogui.locateOnScreen('dianzan.png')

    # 寻找图片的中心

    center = pyautogui.center(xy)

    # 点赞

    pyautogui.click(center)

    print('点赞成功')

 

count = 3 # 点赞次数

while range(count):

    if pyautogui.locateOnScreen('dianzan.png'):

        zan(count)   # 调用点赞函数

        count-=1

    else:

        #本页没有图片后,滚动鼠标;

        pyautogui.scroll(-500)

        print('没有找到目标,屏幕下滚~')

        count -= 1

print('点赞结束!')

登录后复制

未点赞之前的图片是这样的:
在这里插入图片描述

自动点赞之后:
在这里插入图片描述
是不是很厉害呢?其实pyautogui还可以做很多东西,比如说自动发信息,其原理还是不变的,找到对应的位置,输入内容,发送就可以了,在这里我就不演示啦!有兴趣的可以去试试哦~~~

完整代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

from PIL import Image

import pyautogui

import time

 

# 截取整个屏幕

im=pyautogui.screenshot()

# 截取点赞图片

om=im.crop((1754,595,1803,631)) 

#将图片保存供pyautogui.locateOnScreen()使用

om.save("dianzan.png")

 

# 点赞函数

def zan(count): #为了防止一直运行下去,点赞次数由自己定义

    time.sleep(0.5)

    # 寻找刚才保存点赞手势图片

    xy = pyautogui.locateOnScreen('dianzan.png')

    # 寻找图片的中心

    center = pyautogui.center(xy)

    # 点赞

    pyautogui.click(center)

    print('点赞成功')

 

count = 3 # 点赞次数

while range(count):

    if pyautogui.locateOnScreen('dianzan.png'):

        zan(count)   # 调用点赞函数

        count-=1

    else:

        #本页没有图片后,滚动鼠标;

        pyautogui.scroll(-500)

        print('没有找到目标,屏幕下滚~')

        count -= 1

print('点赞结束!')

登录后复制

【相关推荐:Python3视频教程

以上是完全掌握Python自动操作GUI之PyAutoGUI的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

xml格式怎么打开 xml格式怎么打开 Apr 02, 2025 pm 09:00 PM

用大多数文本编辑器即可打开XML文件;若需更直观的树状展示,可使用 XML 编辑器,如 Oxygen XML Editor 或 XMLSpy;在程序中处理 XML 数据则需使用编程语言(如 Python)与 XML 库(如 xml.etree.ElementTree)来解析。

有什么手机APP可以将XML转换成PDF? 有什么手机APP可以将XML转换成PDF? Apr 02, 2025 pm 08:54 PM

无法找到一款将 XML 直接转换为 PDF 的应用程序,因为它们是两种根本不同的格式。XML 用于存储数据,而 PDF 用于显示文档。要完成转换,可以使用编程语言和库,例如 Python 和 ReportLab,来解析 XML 数据并生成 PDF 文档。

手机XML转PDF,转换速度快吗? 手机XML转PDF,转换速度快吗? Apr 02, 2025 pm 10:09 PM

手机XML转PDF的速度取决于以下因素:XML结构的复杂性手机硬件配置转换方法(库、算法)代码质量优化手段(选择高效库、优化算法、缓存数据、利用多线程)总体而言,没有绝对的答案,需要根据具体情况进行优化。

怎么在手机上把XML文件转换为PDF? 怎么在手机上把XML文件转换为PDF? Apr 02, 2025 pm 10:12 PM

不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。

XML如何修改注释内容 XML如何修改注释内容 Apr 02, 2025 pm 06:15 PM

对于小型XML文件,可直接用文本编辑器替换注释内容;对于大型文件,建议借助XML解析器进行修改,确保效率和准确性。删除XML注释时需谨慎,保留注释通常有助于代码理解和维护。进阶技巧中提供了使用XML解析器修改注释的Python示例代码,但具体实现需根据使用的XML库进行调整。修改XML文件时注意编码问题,建议使用UTF-8编码并指定编码格式。

XML修改内容需要编程吗 XML修改内容需要编程吗 Apr 02, 2025 pm 06:51 PM

修改XML内容需要编程,因为它需要精准找到目标节点才能增删改查。编程语言有相应库来处理XML,提供API像操作数据库一样进行安全、高效、可控的操作。

xml格式化工具推荐 xml格式化工具推荐 Apr 02, 2025 pm 09:03 PM

XML格式化工具可以将代码按照规则排版,提高可读性和理解性。选择工具时,要注意自定义能力、对特殊情况的处理、性能和易用性。常用的工具类型包括在线工具、IDE插件和命令行工具。

有没有免费的手机XML转PDF工具? 有没有免费的手机XML转PDF工具? Apr 02, 2025 pm 09:12 PM

没有简单、直接的免费手机端XML转PDF工具。需要的数据可视化过程涉及复杂的数据理解和渲染,市面上所谓的“免费”工具大多体验较差。推荐使用电脑端的工具或借助云服务,或自行开发App以获得更靠谱的转换效果。

See all articles