我想写一个小应用程序,当它被插入时,它将在一个小文本浏览器中显示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")我甚至用指纹来测试循环有多远。下面是初始化和main
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()当执行时,它会打印前两个打印,并且该插槽永远不会被调用。
从我开始学习蟒蛇到现在已经一个星期了。
发布于 2016-11-26 02:00:53
在启动事件循环之前,需要启动监视器。另外,避免使用@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设备,只是为了确保一切正常。
https://stackoverflow.com/questions/40813884
复制相似问题