from pynput import keyboard
def on_press(key):
print(f’{key} :pushed’)
def on_release(key):
if key == keyboard.Key.esc:
return False
with keyboard.Listener(on_press=on_press, on_release=on_release) as lsn:
lsn.join()
随意敲击键盘,你就会从控制台看到这样的输出:
代码内容就是两个方法,一个是监听按键事件,另一个是监听退出事件——敲击 ESC
按键后释放就退出了。
监控鼠标
如果还要监听鼠标事件,那么上这段代码就行了:
from pynput import mouse
def on_click(x, y, button, pressed):
if button == mouse.Button.left:
print(‘left was pressed!’)
elif button == mouse.Button.right:
print(‘right was pressed!’)
return False
else:
print(‘mid was pressed!’)
# 定义鼠标监听线程
with mouse.Listener(on_click=on_click) as listener:
listener.join()
这段代码主要是监听鼠标的左右键点击操作,运行之后操作鼠标,就可以看到控制台打印如下结果:
细心的你一定会发现,每次点击事件,都打印了两次。这是因为按下和松开都会触发鼠标事件。
记录监控日志
键盘事件和鼠标事件都有了,是时候将二者结合起来,把用户的操作记录到日志了。这里我们用 loguru 来记录日志,这个 python 模块我们之前的文章也讲过。
整个代码如下:
from pynput import keyboard, mouse
from loguru import logger
from threading import Thread
# 定义日志文件
logger.add(‘moyu.log’)
def on_press(key):
logger.debug(f’{key} :pushed’)
def on_release(key):
if key == keyboard.Key.esc:
return False
# 定义键盘监听线程
def press_thread():
with keyboard.Listener(on_press=on_press, on_release=on_release) as lsn:
lsn.join()
def on_click(x, y, button, pressed):
if button == mouse.Button.left:
logger.debug(‘left was pressed!’)
elif button == mouse.Button.right:
logger.debug(‘right was pressed!’)
else:
return False
# 定义鼠标监听线程
def click_thread():
with mouse.Listener(on_click=on_click) as listener:
listener.join()
if name == ‘main’:
# 起两个线程分别监控键盘和鼠标
t1 = Thread(target=press_thread())
t2 = Thread(target=click_thread())
t1.start()
t2.start()
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!