The __builtin__
module was renamed to builtins
in Python3.
This change solves 2 sources of confusion for the average Python developer.
- Is it
'__builtins__'
or'__builtin__'
that is in the global namespace?
Darn s! - Is
__builtin__
a special method name or a module? I can’t
tell.
This confusion mainly arises because of the violation of pep8 convention. Also, the lack of pluralization on the module hinders communication as well. Both of these are greatly illustrated by the lengths Guido must go to explain the following from http://mail.python.org/pipermail/python-ideas/2009-March/003821.html:
[CPython] looks at the globals, which contain a special magic entry
__builtins__
(with an ‘s’) which is the dict where built-in functions are looked up. When this dict is the same object as the default
built-in dict (which is__builtin__.__dict__
where__builtin__
—
without ‘s’ — is the module defining the built-in functions) it gives
you supervisor privileges;…
For example,
Python2.7
>>> import __builtin__
>>> vars(globals()['__builtins__']) is vars(__builtin__)
True
>>>
Python3.2
>>> import builtins
>>> vars(globals()['__builtins__']) is vars(builtins)
True
>>>
Related resources:
Other name changes – http://docs.pythonsprints.com/python3_porting/py-porting.html#name-changes
For a succinct explanation of how __builtins__
is used in name resolution – __builtin__ module in Python