I'm a bit confused about types and classes in Python. For e.g. the following REPL conversation confuses me:
>>> class A: pass
...
>>> a = A()
>>> type(a)
<type 'instance'>
>>> a.__class__
<class __main__.A at 0xb770756c>
>>> type([])
<type 'list'>
>>> [].__class__
<type 'list'>
>>> type(list)
<type 'type'>
>>> list.__class__
<type 'type'>
>>> type(A)
<type 'classobj'>
>>> A.__class__
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: class A has no attribute '__class__'
- Why is the type and class for inbuilt things (e.g. list here) the same but different for user classes/types?
- Isn't every class an instance of some other class (like Class in Java)? Why no
__class__for user defined classes?
Any explanation/further reading which can clarify this behaviour would be much appreciated. TIA.
3 Answers 3
You're encountering the different behavior for new style classes versus classic classes. For further reading read this: Python Data Model. Specifically read the section on classes and the difference between new style and classic classes.
Try typing the following into your REPL:
class A: pass
class B(object): pass
and you'll see that you get different results. Here you're dealing with the difference between new style and old style classes. Using Python 2.6.1 here's what I get:
> type(A)
<type "classobj">
> type(B)
<type "type">
which tells you that lists are new style classes and not old style classes. We can further play around with things using list as well:
> type(list)
<type "type">
same as our class B(object): pass result. And also
> c = []
> type(c)
<type "list">
which is telling you about the instance of the object and not it's definition.
3 Comments
type(A) returns <class 'type'>It's "Hystorical reasons". Or possible "Histerical". It's all fixed in Python 3:
>>> class A: pass
...
>>> a = A()
>>> type(a)
<class '__main__.A'>
>>> a.__class__
<class '__main__.A'>
>>> type([])
<class 'list'>
>>> [].__class__
<class 'list'>
>>> type(list)
<class 'type'>
>>> list.__class__
<class 'type'>
>>> type(A)
<class 'type'>
>>> A.__class__
<class 'type'>
>>> class B(object): pass
...
>>> type(B)
<class 'type'>
>>> b = B()
>>> type(b)
<class '__main__.B'>
2 Comments
object derive from object then?type(class) is invaild, but type(type) is <class 'type'>. the former might be less suprising if you compare to type(def).In Python 3.0, user-defined class objects are instances of the object named type, which is itself a class. • In Python 2.6, new-style classes inherit from object, which is a subclass of type; • classic classes are instances of type and are not created from a class.
class A(object). Then you will get<class '__main__.A'>fortype(a).