我完全知道这不是您通常想要做的事情。
我正在使用一个(不幸的)具有很多类型检查功能的库。但是,只有在库中的那些类型检查之一被注释掉时,我才有一个可行的解决方案。我想要一个不需要修改库代码的解决方案。
更具体地说,我需要绕过这段代码:
def is_valid(arg):
return inspect.isclass(arg) and issubclass(arg, SomeClass)
我的arg
不可能是SomeClass
的子类,因为SomeClass
的元类中发生了某些事情,而这对于我的情况是不希望发生的。
所以唯一的选择就是破解。我能以某种方式使Python认为arg
是从SomeClass
继承而实际上却不是吗?
答案 0 :(得分:2)
我想你可以做到...
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