给定一个类Foo
(无论它是否是新型类),如何生成所有基类-在继承层次结构中的任何位置issubclass
?
给定一个类Foo
(无论它是否是新型类),如何生成所有基类-在继承层次结构中的任何位置issubclass
?
Answers:
inspect.getmro(cls)
适用于新样式和旧样式类,并以与NewClass.mro()
方法解析相同的顺序返回:类及其所有祖先类的列表。
>>> class A(object):
>>> pass
>>>
>>> class B(A):
>>> pass
>>>
>>> import inspect
>>> inspect.getmro(B)
(<class '__main__.B'>, <class '__main__.A'>, <type 'object'>)
inspect.getmro(obj)
代替inspect.getmro(type(obj))
。
请参阅python上的可用__bases__
属性class
,该属性包含基类的元组:
>>> def classlookup(cls):
... c = list(cls.__bases__)
... for base in c:
... c.extend(classlookup(base))
... return c
...
>>> class A: pass
...
>>> class B(A): pass
...
>>> class C(object, B): pass
...
>>> classlookup(C)
[<type 'object'>, <class __main__.B at 0x00AB7300>, <class __main__.A at 0x00A6D630>]
getmro
明确指出“在该元组中没有类出现多次”的原因?
__bases__
只能上一层。(正如您的递归实用程序所暗示的那样,但是粗略地看一下示例可能无法理解这一点。)
inspect.getclasstree()
将创建一个嵌套的类及其基列表。用法:
inspect.getclasstree(inspect.getmro(IOError)) # Insert your Class instead of IOError.
python -c 'import inspect; from pprint import pprint as pp; pp(inspect.getclasstree(inspect.getmro(IOError)))'
根据Python文档,我们还可以简单地使用class.__mro__
属性或class.mro()
方法:
>>> class A:
... pass
...
>>> class B(A):
... pass
...
>>> B.__mro__
(<class '__main__.B'>, <class '__main__.A'>, <class 'object'>)
>>> A.__mro__
(<class '__main__.A'>, <class 'object'>)
>>> object.__mro__
(<class 'object'>,)
>>>
>>> B.mro()
[<class '__main__.B'>, <class '__main__.A'>, <class 'object'>]
>>> A.mro()
[<class '__main__.A'>, <class 'object'>]
>>> object.mro()
[<class 'object'>]
>>> A in B.mro()
True
尽管Jochen的回答非常有帮助和正确,但是您可以使用inspect模块的.getmro()方法获得类层次结构,但是突出显示Python的继承层次结构也很重要:
例如:
class MyClass(YourClass):
继承类
例如:
class YourClass(Object):
继承的类
一个类可以从另一个类继承-该类的属性是继承的-特别是其方法是继承的-这意味着继承(子)类的实例可以访问该继承(父)类的属性
实例->类->然后继承的类
使用
import inspect
inspect.getmro(MyClass)
将在Python中向您显示层次结构。