给定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'