我有这种结构:
class Foo:
def __init__(self, val1):
self.val1 = val1
def changeToGoo(self)
HOW???
class Goo(Foo):
def __init__(self, val1, val2):
super(val1)
self.val2 = val2
a = Foo(1)
a.changeToGoo()
'a'现在是Foo的一个实例 现在我想通过使用方法“changeToGoo”将其更改为Goo的实例,并添加其他值。
如何在Python中完成?
我试过了:
self.__class__ = Goo
但是当我检查时:
type(a)
它仍然是Foo,而不是Goo。
答案 0 :(得分:6)
在Python 2中,让Foo
继承自object
,使其成为新式的类:
>>> class Foo(object):
... def __init__(self, val1):
... self.val1 = val1
...
>>> class Goo(Foo):
... def __init__(self, val1, val2):
... super(val1)
... self.val2 = val2
...
>>> f=Foo(1)
>>> f.__class__
<class '__main__.Foo'>
>>> f.__class__ = Goo
>>> f
<__main__.Goo object at 0x10e9e6cd0>
>>> type(f)
<class '__main__.Goo'>
现在您可以更改self.__class__
。在changeToGoo()
方法中:
def changeToGoo(self)
self.__class__ = Goo
self.val2 = 'some value'
或重复使用__init__
:
def changeToGoo(self)
self.__class__ = Goo
self.__init__(self.val1, 'some value')
这确实使你的对象有点怪异,因为它们改变了身份。变形很少是一个好主意。您可能想重新考虑您的用例。
答案 1 :(得分:2)
你可以这样做:
def changeToGoo(self, val2):
return Goo(self.val1, val2)
然后调用并分配,添加额外属性
a = a.changeToGoo(val2)