Python監(jiān)聽鍵盤和鼠標(biāo)事件的示例代碼
我們可以利用windows提供的api函數(shù)來(lái)實(shí)現(xiàn)對(duì)系統(tǒng)鍵盤事件和鼠標(biāo)事件的監(jiān)聽,主要利用的是SetWindowsHookEx函數(shù),這個(gè)函數(shù)可以允許調(diào)用者傳入一個(gè)鉤子函數(shù)也叫回調(diào)函數(shù),當(dāng)指定的事件發(fā)生時(shí),你
傳入的函數(shù)就會(huì)被觸發(fā),有些事件是進(jìn)程級(jí)的,有些事件是系統(tǒng)級(jí)的,這里我們用WH_KEYBOARD_LL來(lái)監(jiān)聽系統(tǒng)鍵盤事件,用WH_MOUSE_LL來(lái)監(jiān)聽鼠標(biāo)事件,注意不是WH_KEYBOARD,使用WH_KEYBOARD是無(wú)法監(jiān)聽到外部
程序的事件的,這個(gè)可以在windows官方文檔里面看到說(shuō)明,要用WH_KEYBOARD來(lái)監(jiān)聽系統(tǒng)鍵盤必須寫dll去實(shí)現(xiàn)。
因?yàn)橛玫搅艘恍┖甓x在win32con里面已經(jīng)有了,所以需要安裝一下pypiwin32,當(dāng)然如果你將這些宏定義寫在自己的文件中,那么就不用安裝pypiwin32了。
安裝pypiwin32
pip install pypiwin32
# coding=utf-8 from ctypes import * from ctypes import wintypes import win32con SetWindowsHookEx=windll.user32.SetWindowsHookExA UnhookWindowsHookEx=windll.user32.UnhookWindowsHookEx CallNextHookEx=windll.user32.CallNextHookEx GetMessage=windll.user32.GetMessageA GetModuleHandle=windll.kernel32.GetModuleHandleW #保存鍵盤鉤子函數(shù)句柄 keyboard_hd = None #保存鼠標(biāo)鉤子函數(shù)句柄 mouse_hd = None class KBDLLHOOKSTRUCT(Structure): _fields_ = [ ('vkCode',c_int), ('scanCode', c_int), ('flags', c_int), ('time', c_int), ('dwExtraInfo', c_uint), ('',c_void_p) ] class POINT(Structure): _fields_ = [ ('x',c_long), ('y',c_long) ] class MSLLHOOKSTRUCT(Structure): _fields_ = [ ('pt',POINT), ('hwnd',c_int), ('wHitTestCode',c_uint), ('dwExtraInfo',c_uint), ] def wait_for_msg(): msg = wintypes.MSG() GetMessage(msg, 0, 0, 0) def keyboard_pro(nCode, wParam, lParam): """ 函數(shù)功能:鍵盤鉤子函數(shù),當(dāng)有按鍵按下時(shí)此函數(shù)被回調(diào) """ if nCode == win32con.HC_ACTION: KBDLLHOOKSTRUCT_p = POINTER(KBDLLHOOKSTRUCT) param=cast(lParam,KBDLLHOOKSTRUCT_p) print(param.contents.vkCode) return CallNextHookEx(keyboard_hd, nCode, wParam, lParam) def start_keyboard_hook(): """ 函數(shù)功能:?jiǎn)?dòng)鍵盤監(jiān)聽 """ HOOKPROTYPE = CFUNCTYPE(c_int, c_int, c_int, POINTER(c_void_p)) pointer = HOOKPROTYPE(keyboard_pro) keyboard_hd = SetWindowsHookEx( win32con.WH_KEYBOARD_LL, pointer, GetModuleHandle(None), 0) wait_for_msg() def stop_keyboard_hook(): """ 函數(shù)功能:停止鍵盤監(jiān)聽 """ UnhookWindowsHookEx(keyboard_hd) def mouse_pro(nCode, wParam, lParam): """ 函數(shù)功能:鼠標(biāo)鉤子函數(shù),當(dāng)有鼠標(biāo)事件,此函數(shù)被回調(diào) """ if nCode == win32con.HC_ACTION: MSLLHOOKSTRUCT_p = POINTER(MSLLHOOKSTRUCT) param=cast(lParam,MSLLHOOKSTRUCT_p) #鼠標(biāo)左鍵點(diǎn)擊 if wParam == win32con.WM_LBUTTONDOWN: print("左鍵點(diǎn)擊,坐標(biāo):x:%d,y:%d" % (param.contents.pt.x,param.contents.pt.y)) elif wParam == win32con.WM_LBUTTONUP: print("左鍵抬起,坐標(biāo):x:%d,y:%d" % (param.contents.pt.x, param.contents.pt.y)) elif wParam == win32con.WM_MOUSEMOVE: print("鼠標(biāo)移動(dòng),坐標(biāo):x:%d,y:%d" % (param.contents.pt.x, param.contents.pt.y)) elif wParam == win32con.WM_RBUTTONDOWN: print("右鍵點(diǎn)擊,坐標(biāo):x:%d,y:%d" % (param.contents.pt.x, param.contents.pt.y)) elif wParam == win32con.WM_RBUTTONUP: print("右鍵抬起,坐標(biāo):x:%d,y:%d" % (param.contents.pt.x, param.contents.pt.y)) return CallNextHookEx(mouse_hd, nCode, wParam, lParam) def start_mouse_hook(): """ 函數(shù)功能:?jiǎn)?dòng)鼠標(biāo)監(jiān)聽 """ HOOKPROTYPE = CFUNCTYPE(c_int, c_int, c_int, POINTER(c_void_p)) pointer = HOOKPROTYPE(mouse_pro) mouse_hd = SetWindowsHookEx( win32con.WH_MOUSE_LL, pointer, GetModuleHandle(None), 0) wait_for_msg() def stop_mouse_hook(): """ 函數(shù)功能:停止鼠標(biāo)監(jiān)聽 """ UnhookWindowsHookEx(mouse_hd)
測(cè)試代碼:
import HookApi if __name__== '__main__': HookApi.start_keyboard_hook()
運(yùn)行效果
以上就是Python監(jiān)聽鍵盤和鼠標(biāo)事件的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于Python監(jiān)聽鍵盤和鼠標(biāo)事件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python 轉(zhuǎn)移文件至云對(duì)象存儲(chǔ)的方法
對(duì)象存儲(chǔ)(Cloud Object Storage,COS)是一種存儲(chǔ)海量文件的分布式存儲(chǔ)服務(wù),具有高擴(kuò)展性、低成本、可靠安全等優(yōu)點(diǎn)。這篇文章主要介紹了Python 轉(zhuǎn)移文件至云對(duì)象存儲(chǔ),需要的朋友可以參考下2021-02-02python sklearn包——混淆矩陣、分類報(bào)告等自動(dòng)生成方式
今天小編就為大家分享一篇python sklearn包——混淆矩陣、分類報(bào)告等自動(dòng)生成方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02解決Tensorflow安裝成功,但在導(dǎo)入時(shí)報(bào)錯(cuò)的問(wèn)題
今天小編就為大家分享一篇解決Tensorflow安裝成功,但在導(dǎo)入時(shí)報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Python實(shí)現(xiàn)雙因素驗(yàn)證2FA的示例代碼
雙因素認(rèn)證(2FA)作為額外安全層為賬號(hào)登錄添加了第二層身份驗(yàn)證。確保賬號(hào)持有人是可以訪問(wèn)數(shù)字身份的唯-用戶。如果不使用雙因表認(rèn)證,企業(yè)將承擔(dān)巨大的安全風(fēng)險(xiǎn)。本文將用Python實(shí)現(xiàn)雙因素驗(yàn)證2FA,需要的可以參考一下2022-07-07使用PIL(Python-Imaging)反轉(zhuǎn)圖像的顏色方法
今天小編就為大家分享一篇使用PIL(Python-Imaging)反轉(zhuǎn)圖像的顏色方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01python3中No module named _ssl的問(wèn)題解決
本文主要介紹了python3中No module named _ssl的問(wèn)題解決,這個(gè)錯(cuò)誤表示Python導(dǎo)入_ssl模塊時(shí)失敗,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08Matplotlib自定義坐標(biāo)軸刻度的實(shí)現(xiàn)示例
這篇文章主要介紹了Matplotlib自定義坐標(biāo)軸刻度的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06