Skip to main content

Hook and simulate keyboard events on Windows and Linux

Project description

keyboard

Take full control of your keyboard with this small Python library. Hook global events, register hotkeys, simulate key presses and much more.

Features

  • Global event hook on all keyboards (captures keys regardless of focus).
  • Listen and send keyboard events.
  • Works with Windows and Linux (requires sudo), with experimental OS X support (thanks @glitchassassin!).
  • Pure Python, no C modules to be compiled.
  • Zero dependencies. Trivial to install and deploy, just copy the files.
  • Python 2 and 3.
  • Complex hotkey support (e.g. ctrl+shift+m, ctrl+space) with controllable timeout.
  • Includes high level API (e.g. record and play, add_abbreviation).
  • Maps keys as they actually are in your layout, with full internationalization support (e.g. Ctrl+ç).
  • Events automatically captured in separate thread, doesn't block main program.
  • Tested and documented.
  • Doesn't break accented dead keys (I'm looking at you, pyHook).
  • Mouse support available via project mouse (pip install mouse).

Usage

Install the PyPI package:

pip install keyboard

or clone the repository (no installation required, source files are sufficient):

git clone https://github.com/boppreh/keyboard

or download and extract the zip into your project folder.

Then check the API docs below to see what features are available.

Example

import keyboard

keyboard.press_and_release('shift+s, space')

keyboard.write('The quick brown fox jumps over the lazy dog.')

keyboard.add_hotkey('ctrl+shift+a', print, args=('triggered', 'hotkey'))

# Press PAGE UP then PAGE DOWN to type "foobar".
keyboard.add_hotkey('page up, page down', lambda: keyboard.write('foobar'))

# Blocks until you press esc.
keyboard.wait('esc')

# Record events until 'esc' is pressed.
recorded = keyboard.record(until='esc')
# Then replay back at three times the speed.
keyboard.play(recorded, speed_factor=3)

# Type @@ then press space to replace with abbreviation.
keyboard.add_abbreviation('@@', 'my.long.email@example.com')

# Block forever, like `while True`.
keyboard.wait()

Known limitations:

  • Events generated under Windows don't report device id (event.device == None). #21
  • Media keys on Linux may appear nameless (scan-code only) or not at all. #20
  • Key suppression/blocking only available on Windows. #22
  • To avoid depending on X, the Linux parts reads raw device files (/dev/input/input*) but this requries root.
  • Other applications, such as some games, may register hooks that swallow all key events. In this case keyboard will be unable to report events.
  • This program makes no attempt to hide itself, so don't use it for keyloggers or online gaming bots. Be responsible.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

keyboard-0.13.4.zip (68.2 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

keyboard-0.13.4.win-amd64.exe (649.0 kB view details)

Uploaded Source

keyboard-0.13.4-py2.py3-none-any.whl (58.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file keyboard-0.13.4.zip.

File metadata

  • Download URL: keyboard-0.13.4.zip
  • Upload date:
  • Size: 68.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.2

File hashes

Hashes for keyboard-0.13.4.zip
Algorithm Hash digest
SHA256 b482b39df2644f62644ed16dce1db072654ba4b0a3eba1000231c129e084fac8
MD5 c80b82d9af7fb9c4bbaaabaadb41b1a9
BLAKE2b-256 5d326f782da2738d88ca3ba8bd7597af3fb3fa379f2c3e465adf1bec9d0396d1

See more details on using hashes here.

File details

Details for the file keyboard-0.13.4.win-amd64.exe.

File metadata

  • Download URL: keyboard-0.13.4.win-amd64.exe
  • Upload date:
  • Size: 649.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.2

File hashes

Hashes for keyboard-0.13.4.win-amd64.exe
Algorithm Hash digest
SHA256 5b712aa97cca64020fc743718fe34f3ba1afd92916419abb1ecaf112c82662e5
MD5 4001be0f4556fdd409f9f1058d71e474
BLAKE2b-256 0aee4a6df2c3b67f46a6d984e004dddc79750c27b65b26a797b641cc99ad6194

See more details on using hashes here.

File details

Details for the file keyboard-0.13.4-py2.py3-none-any.whl.

File metadata

  • Download URL: keyboard-0.13.4-py2.py3-none-any.whl
  • Upload date:
  • Size: 58.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.2

File hashes

Hashes for keyboard-0.13.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 fc394b98c06f8a178918a062ef242cb73789dec4a0159ef41486ed0200dd90ca
MD5 04d533255b36c1cb142fa17b4642f8ae
BLAKE2b-256 186670303b65cde3ddb30cf5a69f4a733d60ad32ae1b4a443a6ac85ae935b5f7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page