我完全知道这不是您通常想要做的事情.
我正在使用具有(很不幸)大量类型检查的库.但是,只有在库中的那些类型检查之一被注释掉时,我才有一个可行的解决方案.我想要一个不需要修改库代码的解决方案.
更具体地说,我需要绕过这段代码:
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