如何从另一个类中的一个类调用方法

时间:2013-04-10 09:11:53

标签: python oop class pyqt4

我在一个文件中有两个类。

主类将具有更新该类中的UI元素的方法。它创建了另一个类的实例。

我想在另一个被实例化的类中更新主类中的UI。

class Add(QtGui.QMainWindow,Ui_AddShotDetails):

    def __init__(self):

        super(Add,self).__init__()
        self.setupUi(self)

    def addDetails(self):

        #Do some stuff and call method in Manager class
        Manager.EpiChange() # I get the error at this line

class Manager(QtGui.QMainWindow,Ui_ShotManager):

    def __init__(self):

        super(Manager,self).__init__()
        self.setupUi(self)
        self.AddWindow = Add()

    def EpiChange(self):

        Manager.EpiCode = str(self.cmb_Epi.currentText())
        # Update ui elements

    def addShot(self):

        self.AddWindow.show()

if __name__ == '__main__':

    app = QtGui.QApplication(sys.argv)
    win = Manager()
    win.show()
    sys.exit(app.exec_())        

我得到以下Traceback

Traceback (most recent call last):
  File "D:\Manager.py", line 18, in addDetails
    Manager.EpiChange()
TypeError: unbound method EpiChange() must be called with Manager instance as first argument (got nothing instead)

我尝试使用@classmethod将此方法设为classmethod如果我使用此方法,我将获得以下追溯

Traceback (most recent call last):
  File "D:\Manager.py", line 27, in EpiChange
    Manager.EpiCode = str(self.cmb_Epi.currentText())
AttributeError: type object 'Manager' has no attribute 'cmb_Epi'

2 个答案:

答案 0 :(得分:6)

def EpiChange(self)

此签名表示您的方法是实例方法,实际上等待实例对象作为第一个参数。

如果你的方法没有对类实例做任何事情,但是需要类本身,它将被称为“类方法”,并且应该等待类本身作为第一个参数。

最后,如果你的方法不需要那些(并且你没有在你的方法签名中使用那些自己的),但你仍然希望它放在某个类中 - 它被称为“静态方法”在Python中。

查看classmethodstaticmethod内置函数(可以使用(通常使用)作为装饰器)。

关于你的代码:看起来你的Add类需要以某种方式传递给它的Manager实例,例如:

class Add(QtGui.QMainWindow,Ui_AddShotDetails):

    def __init__(self, manager):
        super(Add,self).__init__()
        self.manager = manager
        self.setupUi(self)

    def addDetails(self):
        #Do some stuff and call method in Manager class
        self.manager.EpiChange() # I get the error at this line

然后以这种方式创建Add实例:

self.AddWindow = Add(self)

答案 1 :(得分:5)

您正在调用类的函数而不创建它的实例。理论上,您必须创建Manager类的实例,然后调用其方法。类似的东西:

manager_object = Manager()
manager_object.EpicChange()