PyAutoGui 键盘控制函数

键盘控制函数

write() 函数

最核心的键盘功能函数是 write()。该函数将输入所传递字符串中的字符。若要在每次按键之间添加延迟间隔,可通过 interval 命名参数传入整数或浮点数。

示例:

python 复制代码
>>> pyautogui.write('Hello world!')                 # 立即输出"Hello world!"
>>> pyautogui.write('Hello world!', interval=0.25)  # 输出"Hello world!",每个字符输入后延迟0.25秒

write() 函数仅支持输入单字符按键,因此无法处理 Shift 或 F1 等功能键。

press()、keyDown() 和 keyUp() 函数

要按下这类功能键,可调用 press() 函数,并传入 pyautogui.KEYBOARD_KEYS 中的字符串参数,例如 enterescf1。具体请参阅 KEYBOARD_KEYS

示例:

python 复制代码
>>> pyautogui.press('enter')  # 按下回车键
>>> pyautogui.press('f1')     # 按下F1键
>>> pyautogui.press('left')   # 按下左箭头键

press() 函数实质上是 keyDown()keyUp() 函数的封装,这两个函数分别模拟按下和释放按键。它们也可以独立调用。例如,要在按住 Shift 键的同时按三次左箭头键,可执行以下代码:

python 复制代码
>>> pyautogui.keyDown('shift')  # 按住Shift键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.keyUp('shift')    # 释放Shift键

要实现类似 write() 的多键输入效果,可向 press() 传入字符串列表。示例:

python 复制代码
>>> pyautogui.press(['left', 'left', 'left'])

或者可以设置 left 键的按压次数:

python 复制代码
>>> pyautogui.press('left', presses=3)

若要在每次按键之间添加延迟间隔,可通过 interval 命名参数传入整数或浮点数。

hold() 上下文管理器

为便捷实现按键长按操作,可使用 hold() 函数作为上下文管理器,传入 pyautogui.KEYBOARD_KEYS 中的字符串参数(如 shiftctrlalt),该按键将在 with 代码块执行期间保持按下状态。具体请参阅 KEYBOARD_KEYS

python 复制代码
>>> with pyautogui.hold('shift'):
        pyautogui.press(['left', 'left', 'left'])

上述代码等效于:

python 复制代码
>>> pyautogui.keyDown('shift')  # 按住Shift键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.press('left')     # 按下左箭头键
>>> pyautogui.keyUp('shift')    # 释放Shift键

hotkey() 函数

为便捷触发热键或键盘快捷键,hotkey() 函数可接收多个按键字符串参数,这些按键将按顺序按下,并按相反顺序释放。以下代码:

python 复制代码
>>> pyautogui.hotkey('ctrl', 'shift', 'esc')

等效于:

python 复制代码
>>> pyautogui.keyDown('ctrl')
>>> pyautogui.keyDown('shift')
>>> pyautogui.keyDown('esc')
>>> pyautogui.keyUp('esc')
>>> pyautogui.keyUp('shift')
>>> pyautogui.keyUp('ctrl')

若要在每次按键之间添加延迟间隔,可通过 interval 命名参数传入整数或浮点数。

KEYBOARD_KEYS

以下是可以传递给 press()keyDown()keyUp()hotkey() 函数的有效字符串参数列表:

复制代码
['\t', '\n', '\r', ' ', '!', '"', '#', '$', '%', '&', "'", '(',
')', '*', '+', ',', '-', '.', '/', '0', '1', '2', '3', '4', '5', '6', '7',
'8', '9', ':', ';', '<', '=', '>', '?', '@', '[', '\\', ']', '^', '_', '`',
'a', 'b', 'c', 'd', 'e','f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '{', '|', '}', '~',
'accept', 'add', 'alt', 'altleft', 'altright', 'apps', 'backspace',
'browserback', 'browserfavorites', 'browserforward', 'browserhome',
'browserrefresh', 'browsersearch', 'browserstop', 'capslock', 'clear',
'convert', 'ctrl', 'ctrlleft', 'ctrlright', 'decimal', 'del', 'delete',
'divide', 'down', 'end', 'enter', 'esc', 'escape', 'execute', 'f1', 'f10',
'f11', 'f12', 'f13', 'f14', 'f15', 'f16', 'f17', 'f18', 'f19', 'f2', 'f20',
'f21', 'f22', 'f23', 'f24', 'f3', 'f4', 'f5', 'f6', 'f7', 'f8', 'f9',
'final', 'fn', 'hanguel', 'hangul', 'hanja', 'help', 'home', 'insert', 'junja',
'kana', 'kanji', 'launchapp1', 'launchapp2', 'launchmail',
'launchmediaselect', 'left', 'modechange', 'multiply', 'nexttrack',
'nonconvert', 'num0', 'num1', 'num2', 'num3', 'num4', 'num5', 'num6',
'num7', 'num8', 'num9', 'numlock', 'pagedown', 'pageup', 'pause', 'pgdn',
'pgup', 'playpause', 'prevtrack', 'print', 'printscreen', 'prntscrn',
'prtsc', 'prtscr', 'return', 'right', 'scrolllock', 'select', 'separator',
'shift', 'shiftleft', 'shiftright', 'sleep', 'space', 'stop', 'subtract', 'tab',
'up', 'volumedown', 'volumemute', 'volumeup', 'win', 'winleft', 'winright', 'yen',
'command', 'option', 'optionleft', 'optionright']
相关推荐
雨季6662 小时前
构建 OpenHarmony 应用内消息通知模拟器:用纯 UI 演示通知流
flutter·ui·自动化·dart
weixin_403810132 小时前
EasyClick iOS自动化代理IPA挂了 如何再次启动?
android·ios·自动化
iShare_1233 小时前
PyAutoGui 鼠标控制函数
自动化·pyautogui
AC赳赳老秦4 小时前
Notion+DeepSeek:搭建个人工作看板与自动化任务管理规则
前端·javascript·人工智能·自动化·prometheus·notion·deepseek
weixin_403810134 小时前
EasyClick 安卓自动化版本 如何自激活代理模式并且启动安卓的自动化服务
android·自动化·代理模式
叫我:松哥4 小时前
基于flask 智能体的教学演示文档生成及质量评价系统,集成了DeepSeek 大语言模型实现自动化文档生成和多维度质量评估
人工智能·机器学习·信息可视化·语言模型·数据分析·flask·自动化
weixin_462446236 小时前
一键安装 Hadoop 3.3.6 自动化脚本详解 |(含 JAVA_HOME 自动配置)
java·hadoop·自动化
运维行者_15 小时前
2026 技术升级,OpManager 新增 AI 网络拓扑与带宽预测功能
运维·网络·数据库·人工智能·安全·web安全·自动化
AC赳赳老秦20 小时前
Confluence + DeepSeek:构建自动化、智能化的企业知识库文档生成与维护体系
大数据·运维·人工智能·自动化·jenkins·数据库架构·deepseek