我有这段代码:
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)
现在我想检查obj2
和obj3
是obj1
的子类的类的实例,以及Item
的子类。
以下是我的理解,我知道我可以使用isinstance()
查找obj2
是Sub
。我知道我可以使用issubclass(Sub, Item)
。但是,让我说我不知道obj2
是什么类。
我尝试使用issubclass(type(obj2),Item)
,但这不起作用,因为type()
会返回一个我不太了解其工作原理的单独对象。这只是一个问题,虽然我认为这个问题的答案将帮助我解决我遇到的其他一些问题。
此外,我尝试使用某些特殊属性来执行此操作,例如__class__
但我无法弄清楚如何执行此操作。
答案 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