python中使用pyhook实现键盘监控的例子
pyhook下载:http://sourceforge.net/projects/pyhook/files/pyhook/1.5.1/
pyhookAPI手册:http://pyhook.sourceforge.net/doc_1.5.0/
以上网站上提供了几个使用的例子,另外安装pyhooks后,也会有一个例子的文件。于是拿来学习了一下,第一次运行时,提示没有pythoncom模块,就安装了pywin32,安装后,可以正常运行,但是会导致机器发卡,特别是中断程序运行后,鼠标会出现一段时间的自由晃动,找了半天原因,感觉主要是事件频率过高,程序会经常卡在pythoncom.PumpMessages()。
网上搜索了半天,看到有一帖子说是pythoncom.PumpMessages(n),n表示延迟时间,于是试着改了下,发现有一定效果,但不明显,后来想是不是因为没有终止程序,才会导致一直很卡呢,于是添加终止程序语句win32api.PostQuitMessage()。结果还算满意。
#-*-coding:cp936-*- importpythoncom importpyHook importtime importwin32api t='' asciistr='' keystr='' defonKeyboardEvent(event): globalt,asciistr,keystr filename='d://test.txt' wrfile=open(filename,'ab') "处理键盘事件" ift==str(event.WindowName): asciistr=asciistr+chr(event.Ascii) keystr=keystr+str(event.Key) else: t=str(event.WindowName) ifasciistr==''andkeystr=='': wrfile.writelines("\nWindow:%s\n"%str(event.Window)) wrfile.writelines("WindowName:%s\n"%str(event.WindowName))#写入当前窗体名 wrfile.writelines("MessageName:%s\n"%str(event.MessageName)) wrfile.writelines("Message:%d\n"%event.Message) wrfile.writelines("Time:%s\n"%time.strftime('%Y-%m-%d%H:%M:%S',time.localtime())) else: wrfile.writelines("Ascii_char:%s\n"%asciistr) wrfile.writelines("Key_char:%s\n"%keystr) wrfile.writelines("\nWindow:%s\n"%str(event.Window)) wrfile.writelines("WindowName:%s\n"%str(event.WindowName))#写入当前窗体名 wrfile.writelines("Time:%s\n"%time.strftime('%Y-%m-%d%H:%M:%S',time.localtime())) asciistr=chr(event.Ascii) keystr=str(event.Key) ifstr(event.Key)=='F12':#按下F12后终止 wrfile.writelines("Ascii_char:%s\n"%asciistr) wrfile.writelines("Key_char:%s\n"%keystr) wrfile.close() win32api.PostQuitMessage() returnTrue if__name__=="__main__": #创建hook句柄 hm=pyHook.HookManager() #监控键盘 hm.KeyDown=onKeyboardEvent hm.HookKeyboard() #循环获取消息 pythoncom.PumpMessages(10000)