您遇到的问题是,您尝试从其继承的类具有不同的元类:
>>> type(QStandardItem)<class 'sip.wrappertype'> >>> type(ConfigParser)<class 'abc.ABCmeta'>
因此,python无法确定哪个应该是新创建的类的元类。在这种情况下,它必须是一个继承自
sip.wrappertype(或
PyQt5.QtCore.pyqtWrapperType对于较旧的PyQt5版本)和的类
ABCmeta。
因此,可以通过显式引入诸如metaclass之类的类来解决元类冲突:
from PyQt5.QtGui import QStandardItemfrom configparser import ConfigParserclass Finalmeta(type(QStandardItem), type(ConfigParser)): passclass FinalClass(ConfigParser, QStandardItem, metaclass=Finalmeta): def __init__(self, param): ConfigParser.__init__(self) QStandardItem.__init__(self)
如果需要更详细的描述,那么本文是一个好的开始。
但是,我并不真正相信对于这种情况使用多重继承是一个好主意,特别是将多重继承与QObjects一起使用可能会很棘手。也许最好将ConfigParser对象存储为实例变量,并在需要时使用它。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)