Python新样式信号以及线程和gui应用之间的插槽


问题内容

我是OOP和python的新手。我正在尝试使用新样式的信号和插槽将信号从Qthread发射到Qt GUI主窗口。

这是线程。在内部,单击GUI中的“运行”按钮后3秒钟,我将在GUI中发出用于更新消息对话框的信号。我不确定继承是否定义正确或信号是否以正确的方式定义。

class OptimThread (QtCore.QThread):

    signalUpdateMessageDialog = QtCore.SIGNAL("updateMessageDialog(PyQt_PyObject,QString)")

    def __init__(self):
        QtCore.QThread.__init__(self)

    def run(self):

        start = time.time()

        self.emit(self.signalUpdateMessageDialog, time.time() - start, 'Initialising...')

        time.sleep(3)

        self.emit(self.signalUpdateMessageDialog, time.time() - start, 'You waited 3 seconds...')

主类和应用程序部分是这样的(我省略了其他可能无关的代码)。

class Main(QtGui.QMainWindow, Ui_MainWindow):

    def __init__(self, parent=None):
        super(Main, self).__init__(parent)

    def updateMessageDialog(self, times, dialog):

        hours = str(datetime.timedelta(seconds=int(times)))

        self.MessageDialog.insertHtml('<tt>' + hours + ':</tt> ' + dialog + '<br>')

        return
    def clickRun(self):


        self.optimThread = OptimThread()

        self.connect(self.optimThread, QtCore.SIGNAL("updateMessageDialog(PyQt_PyObject,QString)"), self.updateMessageDialog)

        #self.optimThread.signalUpdateMessageDialog.connect(self.updateMessageDialog)

        self.optimThread.start()

if __name__ == '__main__':
    app=QtGui.QApplication(sys.argv)
    window=Main(None)
    app.setActiveWindow(window)
    window.show()
    sys.exit(app.exec_()) # Exit from Python

如果一切都是这样写的,那就行得通。但是,如果我想在Main中使用新样式进行连接:

self.optimThread.signalUpdateMessageDialog.connect(self.updateMessageDialog)

它说:

self.optimThread.signalUpdateMessageDialog.connect(self.updateMessageDialog)AttributeError:’str’对象没有属性’connect’

非常感谢您的建议(与主题和样式有关),并为没有制作MWE表示歉意。


问题答案:

您的示例的结构或多或少是正确的:但是您正在将旧样式的信号槽语法与新样式混合在一起。

信号定义应如下所示:

class OptimThread(QtCore.QThread):
    signalUpdateMessageDialog = QtCore.pyqtSignal(int, str)

信号应该这样发出:

    self.signalUpdateMessageDialog.emit(
        time.time() - start, 'Initialising...')

这就是信号的连接方式:

    self.optimThread.signalUpdateMessageDialog.connect(
        self.updateMessageDialog)

使用新样式的语法,不需要使用SIGNAL()SLOT(),也不需要指定C ++签名。

有关更多详细信息,请参阅PyQt4参考中的新型信号和插槽支持