pyqt 信号槽函数传递失败

目录

背景

创建窗体

基于窗体创建自己的子类

运行程序

结果

分析

修改入口代码

修改自定义类基类

总结


背景

创建窗体

1) 选择 main window

 2) 绘制控件,并为控件添加 事件及槽函数,示例

self.dev_class.currentRowChanged['int'].connect(self.test)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

3)绘制其余控件后,将此文件转换成py文件,即mainwindow.py

基于窗体创建自己的子类

以进行功能定制和扩展,示例代码如下,将原先窗体绘制时的 事件槽函数改成我们自定义的。

class CfgWindow(QMainWindow, Ui_MainWindow):
    def __init__(self, *args, **kwargs):
        super(CfgWindow, self).__init__(*args, **kwargs)
        self.setupUi(self)

        self.dev_class.currentRowChanged['int'].connect(self.change_cfg_class)
        self.show()
    def change_cfg_class(self,index):  (//自定义的槽函数)
        print("index: %d" % index)
        self.stackedWidget.setCurrentIndex(index)

运行程序

添加入口函数,创建窗体并运行。

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = CfgWindow()

    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

结果

当我们运行时,通过改变list widget的选项来触发  currentRowChanged 事件,然而并没有调入我们的槽函数 change_cfg_class

分析

修改入口代码

我们将入口代码改为

if __name__ == '__main__':
    # app = QtWidgets.QApplication(sys.argv)
    app = QApplication(sys.argv)
    # MainWindow = QtWidgets.QMainWindow()
    ui = CfgWindow()

    # ui.setupUi(MainWindow)
    #  MainWindow.show()
    sys.exit(app.exec_())

即不采用Qtwidgets 对窗体进行管理,则可以正常响应事件进入槽函数。

修改自定义类基类

将自定义类的窗体基类由QMainWindow 修改为QtWidgets,运行时报错如下。

class CfgWindow(QtWidgets, Ui_MainWindow):

TypeError: metaclass conflict: the metaclass of a derived class must be a (non-strict) subclass of the metaclasses of all its bases

此时如果需要解决此报错,则需要修改Ui_MainWindow的基类,最终导致我们修改界面创建时的选择,修改为widgets

总结

该问题,如果不创建子类,而是将槽函数直接放入到窗体子类中也不会发生问题。

 各种窗口对应不同的类,每个类应用自己的application进行管理,混搭后易出现莫名其妙的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PyQt中,函数是一种特殊的函数,用于与信号进行交互。当一个信号被触发时,它会自动调用与之关联的函数。你可以在函数传递参数,以实现信号之间的参数传递。 在PyQt中,当一个信号被触发时,它将传递一个或多个参数给关联的函数。这些参数是在调用函数时作为函数的参数传递的。你可以在函数中使用这些参数来执行所需的操作。 下面是一个简单的示例,展示了如何在PyQt传递参数: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton class MyWindow(QMainWindow): def __init__(self): super().__init__() self.button = QPushButton('点击我', self) self.button.clicked.connect(self.on_button_clicked) self.setCentralWidget(self.button) def on_button_clicked(self): # 在函数传递参数 message = '你点击了按钮' self.show_message(message) def show_message(self, message): # 在这里显示消息 self.statusBar().showMessage(message) app = QApplication([]) window = MyWindow() window.show() app.exec_() ``` 在上面的示例中,我们创建了一个`MyWindow`类,它包含一个按钮和一个函数`on_button_clicked`。当按钮被点击时,`on_button_clicked`函数将被调用,并将传递一个字符串`message`作为参数。然后,我们在`show_message`函数中使用这个参数来显示一条消息。 需要注意的是,PyQt信号机制是自动的,不需要手动调用某个方法或使用特殊的方式来传递参数。当信号被触发时,它将自动调用与该信号关联的函数,并将传递的参数作为函数的参数。你可以在函数中使用这些参数来完成所需的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

proware

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值