测试对象是另一个实例类型的子类

时间:2014-12-14 22:51:31

标签: python class inheritance python-3.4

我有这段代码:

class Item:
    def __init__(self,a):
        self.a=a

class Sub(Item):
    def __init__(self,a,b):
        self.b=b
        Item.__init__(self,a)

class SubSub(Sub):
    def __init__(self,a,b,c):
       self.c=c
       Sub.__init__(self,a,b)

obj1=Item(1)
obj2=Sub(1,2)
obj3=SubSub(1,2,3)

现在我想检查obj2obj3obj1的子类的类的实例,以及Item的子类。

以下是我的理解,我知道我可以使用isinstance()查找obj2Sub。我知道我可以使用issubclass(Sub, Item)。但是,让我说我不知道​​obj2是什么类。

我尝试使用issubclass(type(obj2),Item),但这不起作用,因为type()会返回一个我不太了解其工作原理的单独对象。这只是一个问题,虽然我认为这个问题的答案将帮助我解决我遇到的其他一些问题。

此外,我尝试使用某些特殊属性来执行此操作,例如__class__但我无法弄清楚如何执行此操作。

1 个答案:

答案 0 :(得分:13)

您需要使用obj函数提取type()的类型:

isinstance(obj2, type(obj1))

请注意, second 参数是类,第一个是要测试的实例。 type()在这里返回实际的类对象,而不是任何单独的对象

issubclass()适用于您的用例:

issubclass(type(obj2), Item)

演示:

>>> class Item:
...     def __init__(self,a):
...         self.a=a
... 
>>> class Sub(Item):
...     def __init__(self,a,b):
...         self.b=b
...         Item.__init__(self,a)
... 
>>> class SubSub(Sub):
...     def __init__(self,a,b,c):
...        self.c=c
...        Sub.__init__(self,a,b)
... 
>>> obj1=Item(1)
>>> obj2=Sub(1,2)
>>> obj3=SubSub(1,2,3)
>>> isinstance(obj2, type(obj1))
True
>>> issubclass(type(obj2), Item)
True

请注意,如果您在此处重新定义了类,则现有实例将更新为指向新的类对象。如果type(obj2)对您不起作用,则表示用于生成它的类与您现在测试的类不同。

您可以通过测试您的假设来测试是否是这种情况;验证类和实例是否仍然同步,例如:

>>> type(obj1) is Item
True
>>> type(obj2) is Sub
True
>>> type(obj3) is SubSub
True