使用type()
首先,我们来判断对象类型,使用type()函数:
基本类型都可以用type()判断:
>>> type(123)<type 'int'>>>> type('str')<type 'str'>>>> type(none)<type 'nonetype'>
如果一个变量指向函数或者类,也可以用type()判断:
>>> type(abs)<type 'builtin_function_or_method'>>>> type(a)<class '__main__.animal'>
但是type()函数返回的是什么类型呢?它返回type类型。
使用isinstance()
对于class的继承关系来说,使用type()就很不方便。我们要判断class的类型,可以使用isinstance()函数。
我们回顾上次的例子,如果继承关系是:
object -> animal -> dog -> husky
那么,isinstance()就可以告诉我们,一个对象是否是某种类型。先创建3种类型的对象:
>>> a = animal()>>> d = dog()>>> h = husky()
然后,判断:
>>> isinstance(h, husky)true
没有问题,因为h变量指向的就是husky对象。
再判断:
>>> isinstance(h, dog)true
h虽然自身是husky类型,但由于husky是从dog继承下来的,所以,h也还是dog类型。换句话说,isinstance()判断的是一个对象是否是该类型本身,或者位于该类型的父继承链上。
因此,我们可以确信,h还是animal类型:
>>> isinstance(h, animal)true
同理,实际类型是dog的d也是animal类型:
>>> isinstance(d, dog) and isinstance(d, animal)true
但是,d不是husky类型:
>>> isinstance(d, husky)false
能用type()判断的基本类型也可以用isinstance()判断:
>>> isinstance('a', str)true>>> isinstance(u'a', unicode)true>>> isinstance('a', unicode)false
并且还可以判断一个变量是否是某些类型中的一种,比如下面的代码就可以判断是否是str或者unicode:
>>> isinstance('a', (str, unicode))true>>> isinstance(u'a', (str, unicode))true
由于str和unicode都是从basestring继承下来的,所以,还可以把上面的代码简化为:
>>> isinstance(u'a', basestring)true
既然有了type()来判断类型,为什么还有isinstance()呢?一个明显的区别是在判断子类。type()不会认为子类是一种父类类型。isinstance()会认为子类是一种父类类型。
以上就是怎么查看一个对象的类型的详细内容。
