程序员用Python实现自动化控制键盘和鼠标
off999 2024-12-05 15:19 16 浏览 0 评论
本文的主题为介绍如何通过程序自动化控制键盘和鼠标。
要解决什么问题
在我们实际工作生活中,有许多重复性的工作,比如新员工入职流程。除了员工个人信息的不同,其他的流程应该是完全一样,因此此类工作完全可以自动化解决。但是问题来了,有的流程需要填写excel表格,而有些流程需要填写网页表格,这就导致可能比较复杂。那么有没有办法,一个通用的办法来解决这些问题呢?答案是肯定有,我们用最简单的方法,通过Python来控制键盘和鼠标。
实现思路
对于本章的内容我觉得可以帮我们几乎完成任何事情,因为我们可以通过程序来模拟键盘和鼠标的任何操作,这就意味着我们的程序可以像一个机器人一样,根据我们的指令去做任何事情。我们对电脑的操作也就是键盘和鼠标了,因此如果可以通过程序控制键盘鼠标,那么也就意味着我们可以用程序实现任何事情。
当然了,针对某些场景,我们仅仅能够操作鼠标和键盘,还是不能搞定。因为键盘和鼠标仅仅是输入,我们无法获取相应输入操作的输出,比如鼠标点击了某个按钮,我们不知道这个点击操作是否被正确的响应了。那么我们就需要去对输入操作的结果进行一些判定,比如某个按钮的操作完成后,会弹出成功或失败的提示框。仅仅通过键盘和鼠标,我们是无法感知是否有提示框弹出,更不可能知道弹出框的内容是什么。
那么怎么解决这个问题呢?我们前面学习过PIL模块,这里我们可以通过该模块的来进行图片解析,从而确定输入执行后对应的输出是否正确。这样,我们的程序就有一个比较完成的交互行为。
相关模块的安装及介绍
本节将会介绍本章自动化控制键盘和鼠标中会使用到的相关模块。
pyperclip模块
pyperclip模块是一个跨平台的粘贴板模块,实现了复制和粘贴功能。可以通过pip命令进行安装,命令如下。
pip install pyperclip
下面是一个简单的使用pyperclip模块的例子。
>>> import pyperclip
>>> pyperclip.copy('The text to be copied to the clipboard.')
>>> pyperclip.paste()
'The text to be copied to the clipboard.'
pyautogui模块
pyautogui模块是一个面向人类的跨平台GUI自动化模块,可以用编程的方式控制键盘和鼠标,也就是给我们提供了一种通过程序来控制键盘和鼠标的方式。通过pip命令可以进行安装,安装过程如下所示。
PS C:\Program Files (x86)\Python3.6.8\Scripts> pip3 install pyautogui
Collecting pyautogui
Using cached https://files.pythonhosted.org/packages/ec/e6/4aec992002f5bdb3de852978181faa47f79dc176b5447bf9fda2b1a985c6/PyAutoGUI-0.9.47.tar.gz
Collecting pymsgbox (from pyautogui)
Using cached https://files.pythonhosted.org/packages/ac/e0/0ac1ac67178a71b92e46f46788ddd799bb40bff40acd60c47c50be170374/PyMsgBox-1.0.7.tar.gz
Collecting PyTweening>=1.0.1 (from pyautogui)
Using cached https://files.pythonhosted.org/packages/b9/f8/c32a58d6e4dff8aa5c27e907194d69f3b57e525c2e4af96f39c6e9c854d2/PyTweening-1.0.3.zip
Collecting Pillow (from pyautogui)
Using cached https://files.pythonhosted.org/packages/86/00/52d0e56d787c437cd5e6f39929d1ed53b37cbe01280457e29d677b86eceb/Pillow-6.1.0-cp36-cp36m-win32.whl
Collecting pyscreeze>=0.1.21 (from pyautogui)
Using cached https://files.pythonhosted.org/packages/51/11/878e1319ccb41dce8aaf1b6af84d5088d5f4a40fda0348e51b3d1d53f96b/PyScreeze-0.1.22.tar.gz
Collecting pygetwindow>=0.0.5 (from pyautogui)
Using cached https://files.pythonhosted.org/packages/a3/e1/0a96db293bbcb56dd08209f6c1275e9282385526a8900a3411d669b140ee/PyGetWindow-0.0.7.tar.gz
Collecting mouseinfo (from pyautogui)
Using cached https://files.pythonhosted.org/packages/bb/06/07882cebab86cae3c59a1cc99587ccb39ba29f0ba34b463d859df48a2575/MouseInfo-0.0.4.tar.gz
Collecting pyrect (from pygetwindow>=0.0.5->pyautogui)
Using cached https://files.pythonhosted.org/packages/2f/68/bd7bf96fc44217e769f27912e6c9bb3e9987cba286054af6120448ce8212/PyRect-0.1.4.tar.gz
Collecting pyperclip (from mouseinfo->pyautogui)
Using cached https://files.pythonhosted.org/packages/2d/0f/4eda562dffd085945d57c2d9a5da745cfb5228c02bc90f2c74bbac746243/pyperclip-1.7.0.tar.gz
Installing collected packages: pymsgbox, PyTweening, Pillow, pyscreeze, pyrect, pygetwindow, pyperclip, mouseinfo, pyautogui
Running setup.py install for pymsgbox ... done
Running setup.py install for PyTweening ... done
Running setup.py install for pyscreeze ... done
Running setup.py install for pyrect ... done
Running setup.py install for pygetwindow ... done
Running setup.py install for pyperclip ... done
Running setup.py install for mouseinfo ... done
Running setup.py install for pyautogui ... done
Successfully installed Pillow-6.1.0 PyTweening-1.0.3 mouseinfo-0.0.4 pyautogui-0.9.47 pygetwindow-0.0.7 pymsgbox-1.0.7 pyperclip-1.7.0 pyrect-0.1.4 pyscreeze-0.1.22
比如,鼠标的双击,单击和右击等操作,示例代码如下。
import pyautogui as lazy_boy
lazy_boy.click()
lazy_boy.doubleClick()
lazy_boy.rightClick()
lazy_boy.middleClick()
PIL模块
PIL模块是一个Python图像库模块,它包含了很多子模块,我们这里的例子将只使用ImageGrab模块用于图像操作。下面是的代码片段,展示了ImageGrab的简单用法。
from PIL import ImageGrab
def screenshots():
screen_width, screen_height = lazy_boy.size()
rect = (0, 0, screen_width, screen_height)
img = ImageGrab.grab(rect)
return img
代码实现
到现在相关的准备工作已经完成,接下来看看具体实现。
编写伪码
Python代码实现中,将先介绍pyautogui模块的一些基本操作,然后再介绍一个简单的例子,那就是让我们的程序自动打开Notepad++,新建一个文件,输入一段Python代码,最后将该文件保存为Python文件。
# pyautogui模块的基本操作
# 打开Notepad++
# 新建一个文件
# 输入Python代码
# 将该文件保存为Python文件
Python代码
下面的代码介绍pyautogui模块的基本用法,便于了解该模块的基本功能。
import pyautogui as lazy_boy
# 获取当前鼠标的坐标
current_x, current_y = lazy_boy.position()
# 鼠标操作
lazy_boy.moveTo(x, y)
lazy_boy.moveRel()
lazy_boy.locateOnScreen('./test.jpg')
lazy_boy.click(x, y) # 根据坐标x, y单击
lazy_boy.doubleClick()
lazy_boy.rightClick()
lazy_boy.middleClick()
# 拖拽鼠标
lazy_boy.mouseDown()
lazy_boy.dragTo()
lazy_boy.dragRel()
lazy_boy.mouseUp()
lazy_boy.scroll(200)
# 键盘操作
lazy_boy.typewrite(message='Hello world!', interval=0.5)
lazy_boy.press('esc')
lazy_boy.press('enter')
lazy_boy.keyDown('shift')
lazy_boy.keyUp('shift')
lazy_boy.hotkey('ctrl', 'c')
lazy_boy.hotkey('ctrl', 'v')
# 粘贴板操作
import pyperclip
pyperclip.copy('学习Python')
pyperclip.paste()
# 截屏
im = lazy_boy.screenshot('screenshot.png')
# 获取坐标位置的颜色
im.getpixel((x, y))
# 判断坐标(x, y)处的颜色是否为(r, g, b)
lazy_boy.pixelMatchesColor(x, y, (r, g, b))
# 在当前屏幕中查找指定图片(图片需要由系统截图功能截取的图),比如查找按钮坐标
coord = lazy_boy.locateOnScreen('button.png')
# 获取找到的按钮的中心坐标
x, y = lazy_boy.center(coord)
# 在该坐标点右击
lazy_boy.rightClick(x, y)
# 在坐标(120, 110)处输入"Python is a good language!"
lazy_boy.click(120, 110)
lazy_boy.typewrite('Python is a good language!')
# 为输入过程加入延迟
lazy_boy.typewrite('Python is a good language!', 0.3)
#
lazy_boy.FAILSAFE = True
lazy_boy.PAUSE = 1
下面的代码是一个实际案例,比较简单,用于打开Notepad++程序,并新建一个文件,输入两行Python代码,然后将该文件另存为"auto_crreate.py"。
为了点击保存按钮,我们需要提前将保存按钮截图,并存为save.png文件。
import pyperclip
import pyautogui as lazy_boy
lazy_boy.FAILSAFE = True
lazy_boy.PAUSE = 1
# 这个程序将自动打开Notpad++, 新建一个文件,并输入Python代码,最后将其保存为Python文件
lazy_boy.press('win')
lazy_boy.typewrite('Notepad++')
lazy_boy.press('enter')
lazy_boy.hotkey("ctrl", "n")
lazy_boy.typewrite("import os\r\nprint('Hello python')\r\n", 0.5)
pyperclip.copy("This is a test file")
pyperclip.paste()
lazy_boy.hotkey("ctrl", "s")
lazy_boy.typewrite("auto_create.py")
coord = lazy_boy.locateOnScreen('save.png')
print(coord)
# 获取定位到的图中间点坐标
x, y = lazy_boy.center(coord)
lazy_boy.click(x, y)
本文总结
本文介绍了一个非常实用的内容,用Python自动化控制键盘和鼠标,这样当我们遇到一些很棘手的问题,如果没有第三方库支持,那么我们就可以利用本章进行去解决。因为所有的事情都是可以通过键盘和鼠标来完成的,复杂的事情,我们可能需要更多代码和操作步骤,但终究都是可以被搞定的。因此,当读者遇到任何难题的时候,不要轻易彻底放弃,可以短暂搁置,让这件事一直盘旋在自己的脑海中,在空闲的时候,或者某一刻就会有思路从脑海中冒出来。
相关推荐
- 让 Python 代码飙升330倍:从入门到精通的四种性能优化实践
-
花下猫语:性能优化是每个程序员的必修课,但你是否想过,除了更换算法,还有哪些“大招”?这篇文章堪称典范,它将一个普通的函数,通过四套组合拳,硬生生把性能提升了330倍!作者不仅展示了“术”,更传授...
- 7 段不到 50 行的 Python 脚本,解决 7 个真实麻烦:代码、场景与可复制
-
“本文整理自开发者AbdurRahman在Stackademic的真实记录,所有代码均经过最小化删减,确保在50行内即可运行。每段脚本都对应一个日常场景,拿来即用,无需额外依赖。一、在朋...
- Python3.14:终于摆脱了GIL的限制
-
前言Python中最遭人诟病的设计之一就是GIL。GIL(全局解释器锁)是CPython的一个互斥锁,确保任何时刻只有一个线程可以执行Python字节码,这样可以避免多个线程同时操作内部数据结...
- Python Web开发实战:3小时从零搭建个人博客
-
一、为什么选Python做Web开发?Python在Web领域的优势很突出:o开发快:Django、Flask这些框架把常用功能都封装好了,不用重复写代码,能快速把想法变成能用的产品o需求多:行业...
- 图解Python编程:从入门到精通系列教程(附全套速查表)
-
引言本系列教程展开讲解Python编程语言,Python是一门开源免费、通用型的脚本编程语言,它上手简单,功能强大,它也是互联网最热门的编程语言之一。Python生态丰富,库(模块)极其丰富,这使...
- Python 并发编程实战:从基础到实战应用
-
并发编程是提升Python程序效率的关键技能,尤其在处理多任务场景时作用显著。本文将系统介绍Python中主流的并发实现方式,帮助你根据场景选择最优方案。一、多线程编程(threading)核...
- 吴恩达亲自授课,适合初学者的Python编程课程上线
-
吴恩达教授开新课了,还是亲自授课!今天,人工智能著名学者、斯坦福大学教授吴恩达在社交平台X上发帖介绍了一门新课程——AIPythonforBeginners,旨在从头开始讲授Python...
- Python GUI 编程:tkinter 初学者入门指南——Ttk 小部件
-
在本文中,将介绍Tkinter.ttk主题小部件,是常规Tkinter小部件的升级版本。Tkinter有两种小部件:经典小部件、主题小部件。Tkinter于1991年推出了经典小部件,...
- Python turtle模块编程实践教程
-
一、模块概述与核心概念1.1turtle模块简介定义:turtle是Python标准库中的2D绘图模块,基于Logo语言的海龟绘图理念实现。核心原理:坐标系系统:原点(0,0)位于画布中心X轴:向右...
- Python 中的asyncio 编程入门示例-1
-
Python的asyncio库是用于编写并发代码的,它使用async/await语法。它为编写异步程序提供了基础,通过非阻塞调用高效处理I/O密集型操作,适用于涉及网络连接、文件I/O...
- 30天学会Python,开启编程新世界
-
在当今这个数字化无处不在的时代,Python凭借其精炼的语法架构、卓越的性能以及多元化的应用领域,稳坐编程语言排行榜的前列。无论是投身于数据分析、人工智能的探索,还是Web开发的构建,亦或是自动化办公...
- Python基础知识(IO编程)
-
1.文件读写读写文件是Python语言最常见的IO操作。通过数据盘读写文件的功能都是由操作系统提供的,读写文件就是请求操作系统打开一个文件对象(通常称为文件描述符),然后,通过操作系统提供的接口从这个...
- Python零基础到精通,这8个入门技巧让你少走弯路,7天速通编程!
-
Python学习就像玩积木,从最基础的块开始,一步步搭建出复杂的作品。我记得刚开始学Python时也是一头雾水,走了不少弯路。现在回头看,其实掌握几个核心概念,就能快速入门这门编程语言。来聊聊怎么用最...
- 一文带你了解Python Socket 编程
-
大家好,我是皮皮。前言Socket又称为套接字,它是所有网络通信的基础。网络通信其实就是进程间的通信,Socket主要是使用IP地址,协议,端口号来标识一个进程。端口号的范围为0~65535(用户端口...
- Python-面向对象编程入门
-
面向对象编程是一种非常流行的编程范式(programmingparadigm),所谓编程范式就是程序设计的方法论,简单的说就是程序员对程序的认知和理解以及他们编写代码的方式。类和对象面向对象编程:把...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)