键盘控制函数

write()函数

主要的键盘功能是write()。这个函数会输入传入字符串中的字符。若要在按下每个字符键之间添加延迟间隔,请为interval关键字参数传入一个整数或浮点数。

例如:

>>> pyautogui.write('Hello world!')                 # prints out "Hello world!" instantly
>>> pyautogui.write('Hello world!', interval=0.25)  # prints out "Hello world!" with a quarter second delay after each character

使用write()时只能输入单字符按键,因此无法按下Shift或F1等功能键。

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

要按下这些按键,请调用press()函数并传入来自pyautogui.KEYBOARD_KEYS的字符串参数,例如enterescf1。详见KEYBOARD_KEYS

例如:

>>> pyautogui.press('enter')  # press the Enter key
>>> pyautogui.press('f1')     # press the F1 key
>>> pyautogui.press('left')   # press the left arrow key

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

>>> pyautogui.keyDown('shift')  # hold down the shift key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.keyUp('shift')    # release the shift key

要像write()那样同时按下多个键,可以将字符串列表传递给press()。例如:

>>> pyautogui.press(['left', 'left', 'left'])

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

>>> pyautogui.press('left', presses=3)

要在每次按键之间添加延迟间隔,请为interval关键字参数传入整型或浮点型数值。

hold()上下文管理器

为了方便按住某个键,可以使用hold()函数作为上下文管理器,并传入pyautogui.KEYBOARD_KEYS中的字符串(例如shiftctrlalt),该键将在with上下文块执行期间保持按下状态。详见KEYBOARD_KEYS

>>> with pyautogui.hold('shift'):
        pyautogui.press(['left', 'left', 'left'])

…等同于以下代码:

>>> pyautogui.keyDown('shift')  # hold down the shift key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.press('left')     # press the left arrow key
>>> pyautogui.keyUp('shift')    # release the shift key

hotkey()函数

为了方便按下热键或键盘快捷键,hotkey()函数可以接收多个按键字符串,这些按键会按顺序按下,然后以相反顺序释放。这段代码:

>>> pyautogui.hotkey('ctrl', 'shift', 'esc')

…等同于以下代码:

>>> pyautogui.keyDown('ctrl')
>>> pyautogui.keyDown('shift')
>>> pyautogui.keyDown('esc')
>>> pyautogui.keyUp('esc')
>>> pyautogui.keyUp('shift')
>>> pyautogui.keyUp('ctrl')

要在每次按键之间添加延迟间隔,请为interval关键字参数传递一个整数或浮点数。

键盘按键

以下是可传递给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']