在PyQt5的事件循环中使用pyudev.pyqt5

时间:2016-11-26 00:41:49

标签: python-3.x user-interface pyqt5 pyudev

我想写一个小应用程序,它会在插入时在小文本浏览器中显示usb设备的名称。我正在使用pyudev来做到这一点。我没有使用pyudev自己的事件循环,而是发现我们可以通过使用MonitorObserver将pyudev集成到qt的事件循环中。我一直试图这样做,但结果是无用的。 这是我到目前为止尝试过的代码。如果我犯了错误,请告诉我。

进口

from PyQt5.QtCore import pyqtSignal,pyqtSlot,QObject,QSocketNotifier
from PyQt5.QtWidgets import QWidget,QApplication
from form_designer import Ui_Form
from pyudev.pyqt5 import MonitorObserver
from pyudev import Context,Monitor
from PyQt5 import QtCore

小班

class mainWindow(QWidget,Ui_Form):
    def __init__(self,monitor):
        super().__init__()

        self.setupUi(self)
        print("First test")

        monitor.filter_by(subsystem='tty')
        self.observer = MonitorObserver(monitor)
        print("second test")

        self.observer.deviceEvent.connect(self.device_connected)
    @pyqtSlot()
    def device_connected(self,device):
        self.textBrowser.append(device.sys_name)
        print("Test")

我甚至测试过使用打印件来查看循环的进度。 这是初始化和主要的

def main():
    import sys
    app = QApplication(sys.argv)
    context = Context()
    monitor = Monitor.from_netlink(context)
    window = mainWindow(monitor)
    window.show()

    app.exec_()
    monitor.start()
if __name__ == '__main__':
    main()

执行时,它会打印前两个打印件,并且永远不会调用插槽。

仅供参考:自从我开始学习python以来已经过了一周。

1 个答案:

答案 0 :(得分:3)

您需要在启动事件循环之前启动监视器。此外,请避免使用@pyqtSlot装饰器 - 它很少需要,如果您不知道自己在做什么,那么很容易让定义错误(如你在你的例子中做过。)

所以你的代码应该是这样的:

class mainWindow(QWidget, Ui_Form):
    def __init__(self):
        ...
        context = Context()
        monitor = Monitor.from_netlink(context)
        monitor.filter_by(subsystem='tty')
        self.observer = MonitorObserver(monitor)
        self.observer.deviceEvent.connect(self.device_connected)
        monitor.start()

    def device_connected(self, device):
        self.textBrowser.append(device.sys_name)
        print("Test")

def main():
    import sys
    app = QApplication(sys.argv)
    window = mainWindow()
    window.show()
    app.exec_()

PS:最好注释掉filter_by行并插入USB设备,以确保一切正常。