Nate_2020 发表于 2022-10-17 10:20:07

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()

txxcat 发表于 2022-10-17 12:02:56

这个一般情况下解决不了,在idle中运行,始终处于运行环境下,所以代码能一直工作,而编译后运行,运行结束后运行环境一并退出,自然就不能继续了。

Nate_2020 发表于 2022-10-17 15:26:33

txxcat 发表于 2022-10-17 12:02
这个一般情况下解决不了,在idle中运行,始终处于运行环境下,所以代码能一直工作,而编译后运行,运行结束 ...

有什么办法可以一直运行吗?

txxcat 发表于 2022-10-17 16:41:49

Nate_2020 发表于 2022-10-17 15:26
有什么办法可以一直运行吗?

作为解释语言,恐怕python目前为止做不到这点,这种功能需要C一类的语言来编写了。

阿奇_o 发表于 2022-10-17 17:27:14

本帖最后由 阿奇_o 于 2022-10-17 17:31 编辑

应该是你 没理解 non-block非阻塞式 和 block阻塞式 的区别, 用错了。

再仔细看看官方文档吧,然后,根据你的需求,应该是改写为 block模式 。

或者,你把现在这种non-block模式,改写和放到 GUI的main-loop里(如果你刚好涉及GUI类似的逻辑)。

其次,根据你当前的需求,或许无需用面向对象来封装on_click等方法,不然你可能不太会改写和调用(官方的例子是非面向对象的)

页: [1]
查看完整版本: pyinstaller打包后不能做鼠标