我完全知道这不是您通常想要做的事情.
我正在使用具有(很不幸)大量类型检查的库.但是,只有在库中的那些类型检查之一被注释掉时,我才有一个可行的解决方案.我想要一个不需要修改库代码的解决方案.
更具体地说,我需要绕过这段代码:
def is_valID(arg): return inspect.isclass(arg) and issubclass(arg,SomeClass)
我的arg不可能是SomeClass的子类,因为SomeClass的元类中发生了某些事情,这对于我的情况是不希望发生的.
因此,唯一的选择就是入侵.我可以以某种方式使Python认为arg从SomeClass继承而实际上却不是吗?
最佳答案我想你可以做…import inspectdef is_valID(arg): return inspect.isclass(arg) and issubclass(arg,Base)class OtherType(type): passclass Base(Metaclass=OtherType): passclass SurpriseBase: passclass SurpriseDerived(SurpriseBase): passprint(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: FalseBase Metaclass: <class '__main__.OtherType'>SurpriseDerived Metaclass: <class 'type'>SurpriseDerived is_valID: True
总结 以上是内存溢出为你收集整理的更改类继承的类的列表 全部内容,希望文章能够帮你解决更改类继承的类的列表 所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)