pyinstaller打包后不能做鼠标
以下代码在idle的原代码里可以正常运行, 会在G:\time.txt文件中记录鼠标点击时间,但把程序用pyinstaller转成exe文件后确不会记录鼠标点击时间是怎么回事?
from pynput import mouse
import time
class mousetimer():
def __init__(self,):
# 初始化SB的释放状态
self.start_time = 0
def on_click(self, x, y, button, pressed):
# 按下 SB 左键开始计时
if str(button) == 'Button.left' and pressed:
self.start_time = time.time()
with open(r'G:\time.txt', 'a') as file_object:
file_object.write(str(self.start_time)+'\n')
def start(self):
# 需要监听的 SB 事件
listener = mouse.Listener(on_click=self.on_click, suppress=False)
# 开始监听
listener.start()
if __name__ == '__main__':
mouse_timer = mousetimer()
mouse_timer.start() 这个一般情况下解决不了,在idle中运行,始终处于运行环境下,所以代码能一直工作,而编译后运行,运行结束后运行环境一并退出,自然就不能继续了。 txxcat 发表于 2022-10-17 12:02
这个一般情况下解决不了,在idle中运行,始终处于运行环境下,所以代码能一直工作,而编译后运行,运行结束 ...
有什么办法可以一直运行吗? Nate_2020 发表于 2022-10-17 15:26
有什么办法可以一直运行吗?
作为解释语言,恐怕python目前为止做不到这点,这种功能需要C一类的语言来编写了。 本帖最后由 阿奇_o 于 2022-10-17 17:31 编辑
应该是你 没理解 non-block非阻塞式 和 block阻塞式 的区别, 用错了。
再仔细看看官方文档吧,然后,根据你的需求,应该是改写为 block模式 。
或者,你把现在这种non-block模式,改写和放到 GUI的main-loop里(如果你刚好涉及GUI类似的逻辑)。
其次,根据你当前的需求,或许无需用面向对象来封装on_click等方法,不然你可能不太会改写和调用(官方的例子是非面向对象的)
页:
[1]