Python:将超类实例转换为子类



给定A类的对象a。我不明白A类是如何工作的。此外,在我使用的整个模块中有未知数量的方法使用A。因此,对于所有实际目的,A是未知的,我们只能操作它的一个实例和一个已知的方法method2

我得到一个实例a。我想将a转换为B类,这样它在各个方面都保持相同,除了method2(它存在于原始类A中并打印a)现在打印b。我该如何修改下面的代码才能做到这一点呢?

class B(A):
def __init__(self,**kwargs):
super().__init__(**kwargs)
def method2(self):
print('b')
a.method1() #prints '1'
a.method2() #prints 'a'
print(a[0]) #prints 1
#a = convertAtoB(a)
a.method1() #prints '1'
a.method2() #should print 'b'
print(a[0]) #prints 1

我知道之前有一个类似问题的答案,涉及使用__getattr__,但是当尝试下面的代码时:

class B(object):
def __init__(self, a):
self.__a = a
def __getattr__(self, attr):
return getattr(self.__a, attr)
def __setattr__(self, attr, val):
object.__setattr__(self, attr, val)

def method2(self):
print('b')

我得到了,在实际问题中,我有,错误TypeError: 'B' object is not subscriptable

edit:添加了一个下标测试,正如我上面提到的,我不完全理解A是如何工作的,或者导入模块中的哪些方法需要A才能工作。

您可以将对象的__class__重新分配给新类型。我在代码中添加了注释:(必要时自己负责对象初始化)

class A:
def func_A_1(self):
return 'func_A_1 is running'
def func_A_2(self):
return 'func_A_2 is running'
def method2(self):
return 'method2 of class A'

class B(A):
def method2(self):
return 'method2 of class B'

obj = A()
print(obj)
print(obj.func_A_1())
print(obj.method2())
print('------------------------------')
# turning object of A to B
obj.__class__ = B
print(obj)
# still have access to A's methods
print(obj.func_A_1())
# This method is now for B
print(obj.method2())

输出:

<__main__.A object at 0x0000012FECFACFD0>
func_A_1 is running
method2 of class A
------------------------------
<__main__.B object at 0x0000012FECFACFD0>
func_A_1 is running
method2 of class B

不覆盖__init__,只覆盖method2,只设置a = B()。或:

class B(A):
def method2(self):
print('b')
def convertAtoB(a):
a.method2 = B().method2
return a
a.method1() #prints '1'
a.method2() #prints 'a'
#a = convertAtoB(a)
a.method1() #prints '1'
a.method2() #should print 'b'

最新更新