我完全知道这不是您通常想要做的事情.
我正在使用具有(很不幸)大量类型检查的库.但是,只有在库中的那些类型检查之一被注释掉时,我才有一个可行的解决方案.我想要一个不需要修改库代码的解决方案.
更具体地说,我需要绕过这段代码:
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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。