更改 classes 的列表 a class 继承自
Change the list of classes a class inherits from
我完全知道这不是你通常想做的事情。
我正在使用一个具有(不幸的)大量类型检查功能的库。但是,只有当库中的其中一个类型检查被注释掉时,我才有一个可行的解决方案。我想要一个不需要修改库代码的解决方案。
更具体地说,我需要绕过这段代码:
def is_valid(arg):
return inspect.isclass(arg) and issubclass(arg, SomeClass)
我的 arg
不可能是 SomeClass
的子类,因为 SomeClass
的元类中发生了一些我不想发生的事情。
所以唯一的选择就是破解。我能否以某种方式让 Python 认为 arg
继承自 SomeClass
而实际上并非如此?
我想你可以做到这一点...
import inspect
def is_valid(arg):
return inspect.isclass(arg) and issubclass(arg, Base)
class OtherType(type):
pass
class Base(metaclass=OtherType):
pass
class SurpriseBase:
pass
class SurpriseDerived(SurpriseBase):
pass
print(f'SurpriseDerived is_valid: {is_valid(SurpriseDerived)}')
SurpriseDerived.__bases__ = (Base,)
print(f'Base metaclass: {type(Base)}')
print(f'SurpriseDerived metaclass: {type(SurpriseDerived)}')
print(f'SurpriseDerived is_valid: {is_valid(SurpriseDerived)}')
输出:
SurpriseDerived is_valid: False
Base metaclass: <class '__main__.OtherType'>
SurpriseDerived metaclass: <class 'type'>
SurpriseDerived is_valid: True
我完全知道这不是你通常想做的事情。
我正在使用一个具有(不幸的)大量类型检查功能的库。但是,只有当库中的其中一个类型检查被注释掉时,我才有一个可行的解决方案。我想要一个不需要修改库代码的解决方案。
更具体地说,我需要绕过这段代码:
def is_valid(arg):
return inspect.isclass(arg) and issubclass(arg, SomeClass)
我的 arg
不可能是 SomeClass
的子类,因为 SomeClass
的元类中发生了一些我不想发生的事情。
所以唯一的选择就是破解。我能否以某种方式让 Python 认为 arg
继承自 SomeClass
而实际上并非如此?
我想你可以做到这一点...
import inspect
def is_valid(arg):
return inspect.isclass(arg) and issubclass(arg, Base)
class OtherType(type):
pass
class Base(metaclass=OtherType):
pass
class SurpriseBase:
pass
class SurpriseDerived(SurpriseBase):
pass
print(f'SurpriseDerived is_valid: {is_valid(SurpriseDerived)}')
SurpriseDerived.__bases__ = (Base,)
print(f'Base metaclass: {type(Base)}')
print(f'SurpriseDerived metaclass: {type(SurpriseDerived)}')
print(f'SurpriseDerived is_valid: {is_valid(SurpriseDerived)}')
输出:
SurpriseDerived is_valid: False
Base metaclass: <class '__main__.OtherType'>
SurpriseDerived metaclass: <class 'type'>
SurpriseDerived is_valid: True