Python: Quelle est la différence entre __builtin__ et __ _ _ les builtins__?
J'ai été codage aujourd'hui et a remarqué quelque chose. Si j'ouvre un nouvel interprète session (IDLE) et de vérifier ce qui est défini avec la dir
fonction j'obtiens ceci:
$ python
>>> dir()
['__builtins__', '__doc__', '__name__', '__package__']
>>> dir(__builtins__)
['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BufferError', 'BytesWarning', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EnvironmentError', 'Exception', 'False', 'FloatingPointError', 'FutureWarning', 'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 'MemoryError', 'NameError', 'None', 'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 'ReferenceError', 'RuntimeError', 'RuntimeWarning', 'StandardError', 'StopIteration', 'SyntaxError', 'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'True', 'TypeError', 'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'ZeroDivisionError', '_', '__debug__', '__doc__', '__import__', '__name__', '__package__', 'abs', 'all', 'any', 'apply', 'basestring', 'bin', 'bool', 'buffer', 'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'cmp', 'coerce', 'compile', 'complex', 'copyright', 'credits', 'delattr', 'dict', 'dir', 'divmod', 'enumerate', 'eval', 'execfile', 'exit', 'file', 'filter', 'float', 'format', 'frozenset', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 'int', 'intern', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'long', 'map', 'max', 'memoryview', 'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'quit', 'range', 'raw_input', 'reduce', 'reload', 'repr', 'reversed', 'round', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'unichr', 'unicode', 'vars', 'xrange', 'zip']
>>> import __builtin__
['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BufferError', 'BytesWarning', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EnvironmentError', 'Exception', 'False', 'FloatingPointError', 'FutureWarning', 'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 'MemoryError', 'NameError', 'None', 'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 'ReferenceError', 'RuntimeError', 'RuntimeWarning', 'StandardError', 'StopIteration', 'SyntaxError', 'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'True', 'TypeError', 'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'ZeroDivisionError', '_', '__debug__', '__doc__', '__import__', '__name__', '__package__', 'abs', 'all', 'any', 'apply', 'basestring', 'bin', 'bool', 'buffer', 'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'cmp', 'coerce', 'compile', 'complex', 'copyright', 'credits', 'delattr', 'dict', 'dir', 'divmod', 'enumerate', 'eval', 'execfile', 'exit', 'file', 'filter', 'float', 'format', 'frozenset', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 'int', 'intern', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'long', 'map', 'max', 'memoryview', 'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'quit', 'range', 'raw_input', 'reduce', 'reload', 'repr', 'reversed', 'round', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'unichr', 'unicode', 'vars', 'xrange', 'zip']
>>> dir(__builtin__) == dir(__builtins__) # They seem to have the same things
True
Veuillez noter que la dernière ligne.
Donc, ma question est:
-
Est tout un alias de l'autre?
-
Sont le Python gars de planification pour se débarrasser de l'un de ces?
-
Que dois-je utiliser pour mes propres programmes?
-
Qu'en Python 3?
-
Toute information est utile,!
Important:
Je suis à l'aide de Python 2.7.2+ sur Ubuntu.
Vous devez vous connecter pour publier un commentaire.
Directement à partir de la documentation python:
http://docs.python.org/reference/executionmodel.html
Noter que dans Python3, le module
__builtin__
a été renommébuiltins
pour éviter une partie de cette confusion.__builtin__
module est renommé "objets internes" (sans tiret). docs.python.org/dev/reference/executionmodel.htmlVous devez utiliser
__builtin__
dans vos programmes (dans les rares cas où vous en avez besoin), car__builtins__
est un détail d'implémentation de Disponible. Il peut être soit identiques à__builtin__
, ou à__builtin__.__dict__
, selon le contexte. Comme la documentation dit:En Python 3,
__builtin__
a été renommébuiltins
, et__builtins__
reste le même (vous devez utiliser uniquementbuiltins
en Python 3).Guido voulu unir
__builtin__
et__builtins__
, comme vous pouvez le voir ici ("Ayant__builtins__
et__builtin__
les deux est clairement une mauvaise idée.") mais apparemment , il n'en fut rien.Apparemment l'utilisation de
__builtins__
est pour la performance - il donne un accès direct à__builtin__.__dict__
dans le cas de non-module principal, et donc supprime un niveau d'indirection.__builtin__
est un module contenant les fonctions et les types. Le fait qu'un nom__builtins__
est disponible contenant les mêmes choses, c'est un détail d'implémentation. En d'autres termes, si vous avez besoin d'utiliser l'un d'eux, faireimport __builtin__
et ensuite utiliser__builtin__
. Voir la documentation.Vous pouvez comprendre ces comme le code suivant.
lorsque disponible est commencé, disponible de charge
__builtin__
modules dans l'espace de noms globalimportation
__builtin__
comme__builtins__