• This repository has been archived on 09/Nov/2017
  • Stars
    star
    155
  • Rank 240,864 (Top 5 %)
  • Language
    Python
  • Created over 9 years ago
  • Updated over 7 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Pure Python hotkey hook, with thanks to pyHook and pyhk

PyHooked: a pure Python hotkey module

Join the chat at https://gitter.im/IronManMark20/pyhooked

ATTENTION: pyhooked has been deprecated in favor of keyboard for new projects. This library is will no longer be supported. Please use one keyboard or one of the alternatives listed in Alternatives.

About -

PyHooked is a pure python keyboard and mouse hotkey module that allows the creation of hotkeys in all Python implementations that support sane implementations of ctypes. Instead of messing around with low level Windows calls, just give Hooked a callback and tell it to start listening.

PyHooked supports IronPython (2.7.5+, incl. 2.7.6 RC2), PyPy (5.3.1+) and CPython (Tested:2.7 x86,3.4 x64,3.5 x86; Most are likely to work) currently. It is pure Python, so porting to other Python implementations and versions should be very simple.

Usage -

Please see example.py for a basic example.

If you are using it with a UI library, please see example_gui.py

Please note that the wiki is out of date, and needs to be updated.

Installing

Just run $ pip install pyhooked or $ pip install git+https://github.com/ethanhs/pyhooked.git to get the latest version.

Alternatives -

pyHook and pyhk inspired the creation of this project. They are great hotkey modules too!

pywinauto is an incredibly useful Windows automation library that also includes among a plethora of tools, a hotkey detection library.

License -

PyHooked Copyright (C) 2015 Ethan Smith This program comes with ABSOLUTELY NO WARRANTY; This is free software, and you are welcome to redistribute it under certain conditions; PyHooked is licensed under the LGPL v3, or at your choice, any later version. This program comes with the lgpl in a .txt file.

Pyhooked v0.8+ is based on work by Maxim Samokhvalov, who has my graditude for his work, and others in the PyWinAuto project, licensed under the BSD 3-clause license. The copyright notice is given below.

 Copyright (C) 2016 Maxim Samokhvalov
 Copyright (C) 2016 Vasily Ryabov
 Copyright (C) 2016 ethanhs
 All rights reserved.

 Redistribution and use in source and binary forms, with or without
 modification, are permitted provided that the following conditions are met:

 * Redistributions of source code must retain the above copyright notice, this
   list of conditions and the following disclaimer.

 * Redistributions in binary form must reproduce the above copyright notice,
   this list of conditions and the following disclaimer in the documentation
   and/or other materials provided with the distribution.

 * Neither the name of pywinauto nor the names of its
   contributors may be used to endorse or promote products derived from
   this software without specific prior written permission.

 * Neither the name of hooks.py nor the names of its
   contributors may be used to endorse or promote products derived from
   this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 

#####As of v0.6, the module is LGPL licensed, not under the GPL.

####The Future - Here are a few things that I would like to see:

  • add support for args for called functions (DONE)
  • get mouse inputs (DONE)
  • support all scancodes found here (DONE)
  • Jython support
  • ????
    I am open to feature requests. If you have ideas, let me know (mr.smittye (at) gmail). Or, even better, make your changes and a pull request!

More Repositories

1

WSL-Programs

A community powered list of programs that work (and those that don't) on the Windows subsystem for Linux
CSS
1,082
star
2

python-wasm

Build scripts and configuration for building CPython for Emscripten
JavaScript
678
star
3

cce

commandline compiler explorer - use https://godbolt.org from your terminal!
Rust
195
star
4

material

Material Design Widgets for PySide and PyQt4
Python
72
star
5

python-typecheckers

A list of Python type checkers (PEP 484 compliant and not, static and runtime/dynamic)
61
star
6

Explore10

Modern File Explorer
C#
29
star
7

clang

Unofficial Python bindings to libclang
Python
27
star
8

ryaml

Python yaml library using Rust
Python
24
star
9

apt.cli.rs

Issues for apt.cli.rs
23
star
10

abserde

Generate fast JSON parsers based on type stubs
Python
13
star
11

pynanosvg

Cythonic wrapper around nanosvg for rasterizing SVGs
Python
10
star
12

windows-setup

Script and description of tricks I use with my Windows setup
PowerShell
8
star
13

typycal

Generate stubs from Python code at runtime (An experiment!)
C++
6
star
14

pep-561

Issue tracker for PEP 561 with sample typed package
Python
5
star
15

mypy.app

Code for mypy.app, a mypy playground that runs in the browser!
Svelte
5
star
16

libgithub

A C++ library for use with Github's API - incomplete and very much a WIP!
C++
4
star
17

pyqml

Python C extension wrapping the minimal Qt Qml API. Still very much a WIP
QML
3
star
18

stub-package

A sample PEP 561 stub package.
Python
3
star
19

personal-puppet

My personal Puppet setup
Puppet
2
star
20

IronShell

A C# Shell replacement - Abandoned - DONT USE THIS!!
C#
2
star
21

ModernResizer

Resize and move the Windows 8 start menu
Python
2
star
22

opcodetrace

Trace CPython 3.6+ to measure opcode usage.
C++
1
star
23

upptime

My personal upptime repo
JSON
1
star
24

Kolox

An implementation of the the lox language in Kotlin to learn Kotlin and more about programming language design :)
Kotlin
1
star
25

ukkonen

A port of https://github.com/sunesimonsen/ukkonen to Rust, for use in Python
Rust
1
star
26

generational-arena-dom

A DOM implementation for html5ever that uses generational-arenas.
Rust
1
star
27

clscreate

Testing class creation times for Cython vs PyO3
Python
1
star