我一直在使用PyQt和跨线程的信号/槽。这里有一个我找不到错误的情况:
我有一个类(MultipleProcessLauncher),它能够在单独的线程中启动多个进程。我捕获每个进程的标准输出并将这些消息发送到一个单一的队列中,该队列由另一个线程(OutputWorker)读取,最后这个线程应该发出一个 onNewMessage 信号(我认为它没有),在主类中捕获,但回调函数从未被调用。
- 进程线程填充队列与消息
- 读取线程捕获所有这些消息(我可以在 while 循环中使用
print(item)
打印它们)
但是: - 读取线程的信号似乎没有发出任何东西,因此主线程的回调函数从未被调用...
非常感谢您的帮助,我认为我在跨线程信号方面缺少了一些东西...
class OutputWorker(QObject):
onNewMessage = pyqtSignal(['QString'])
def __init__(self, queue, parent=None):
super(OutputWorker, self).__init__(parent)
self.queue = queue
def work(self):
while True:
item = self.queue.get()
self.onNewMessage.emit(item)
self.queue.task_done()
class MultipleProcessLauncher(QObject):
commandEvent = pyqtSignal(['QString'])
def __init__(self, parent=None):
super(MultipleProcessLauncher, self).__init__(parent)
self.messaging_queue = Queue()
# Start reading message
self.reading_thread = QThread()
self.worker = OutputWorker(self.messaging_queue)
self.worker.moveToThread(self.reading_thread)
self.worker.onNewMessage.connect(self.command_event)
self.reading_thread.started.connect(self.worker.work)
self.reading_thread.start()
def execute(self, command):
p = subprocess.Popen(command, stdout=subprocess.PIPE)
t = Thread(target=self.enqueue, args=(p.stdout, self.messaging_queue))
t.daemon = True
t.start()
def enqueue(self, stdout, queue):
for line in iter(stdout.readline, b''):
queue.put(line.decode())
stdout.close()
def command_event(self, event):
# This point is never reached
print('message received')
if __name__ == '__main__':
manager = MultipleProcessLauncher()
manager.execute('ipconfig')
time.sleep(100)
item
不会是一个QString
。你可能需要更新你的信号定义为pyqtSignal(str)
或类似的内容。虽然我不确定这是否是问题的原因。 - three_pineapples