从QWidget和另一个基类继承吗?

时间:2018-10-10 17:06:26

标签: python pyqt pyqt5 multiple-inheritance

我试图创建一个PyQt5.QtWidgets.QWidget派生的小部件,同时从另一个基类Base继承。

Base继承会在调用QWidget构造函数时导致错误,说我从未提供Base所需的参数。

这是我尝试调用QWidgetBase构造函数的方式:

class Deriv(QtWidgets.QWidget, Base):
    def __init__(self):
        QtWidgets.QWidget.__init__(self)
        Base.__init__(self, "hello world")

我得到的错误是:

    QtWidgets.QWidget.__init__(self)
TypeError: __init__() missing 1 required positional argument: 'id'

是否可以同时继承QWidgetBase,如果可以的话,如何正确调用它们各自的构造函数?

这是一个示例应用程序,可重现我遇到的错误:

#!/usr/bin/env python3
import sys
from PyQt5 import QtWidgets

class Base(object):
    def __init__(self, id):
        self.id = id

class Deriv(QtWidgets.QWidget, Base):
    def __init__(self):
        QtWidgets.QWidget.__init__(self)
        Base.__init__(self, "hello world")

        self.show()

def main():
    app = QtWidgets.QApplication(sys.argv)
    d = Deriv()
    sys.exit(app.exec_())

if __name__ == '__main__':
    main()

这是回溯:

Traceback (most recent call last):
  File "./test.py", line 22, in <module>
    main()
  File "./test.py", line 18, in main
    d = Deriv()
  File "./test.py", line 11, in __init__
    QtWidgets.QWidget.__init__(self)
TypeError: __init__() missing 1 required positional argument: 'id'

请注意,如果我仅继承自QWidget (因此只需删除引用Base的所有内容),那么代码就会起作用

class Deriv(QtWidgets.QWidget):
    def __init__(self):
        QtWidgets.QWidget.__init__(self)

        self.show()

1 个答案:

答案 0 :(得分:1)

我假设QtWidgets.QWidget.__init__本身使用super来调用__init__。对于您的单个继承案例,MRO由三个类组成:[Deriv, QtWidgets.QWidget, object]。调用super(QtWidgets.QWidget, self).__init__会调用object.__init__,它不需要任何其他参数。

在您的多继承示例中,MRO看起来像

[Deriv, QtWidgets.QWidget, Base, object]

这意味着 now 调用super(QtWidgets.QWidget, self).__init__不是指object.__init__,而是Base.__init__,而 则需要附加参数,导致您看到错误。