2012-06-24 7 views
54

Ich habe heute codiert und etwas bemerkt. Wenn ich eine neue Interpreter-Sitzung öffnen (idle) und überprüfen, was mit der dir Funktion definiert ist ich diese:Python: Was ist der Unterschied zwischen __builtin__ und __builtins__?

$ 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 

Bitte beachten Sie die letzte Zeile.

Also, meine Frage ist:

  • Ist jeder ein Alias ​​des anderen?

  • Sind die Python-Leute vor, eines von denen loszuwerden?

  • Was soll ich für meine eigenen Programme verwenden?

  • Was ist mit Python 3?

  • Alle Informationen sind wertvoll!

Wichtig:

Ich verwende Python 2.7.2+ auf Ubuntu.

Antwort

48

Gerade aus der Python-Dokumentation: http://docs.python.org/reference/executionmodel.html

standardmäßig, wenn sie im __main__ Modul, __builtins__ ist die Einbaumodul __builtin__ (Anmerkung: kein 's'); Wenn in irgendeinem anderen Modul ist __builtins__ ein Alias ​​für das Wörterbuch des __builtin__ Modul selbst.

__builtins__ kann auf ein benutzerdefiniertes Wörterbuch eingestellt werden, um eine schwache Form der eingeschränkten Ausführung zu erstellen.

CPython Implementierung Detail: Benutzer nicht __builtins__ berühren sollte; Es ist streng genommen ein Implementierungsdetail. Benutzer , die Werte im Namensbereich buileins überschreiben möchten, sollten import das Modul __builtin__ (no 's') und seine Attribute entsprechend ändern. Der Namensraum für ein Modul wird automatisch die erstmals ein Modul erstellt wird importiert.

Beachten Sie, dass in Python3 das Modul __builtin__ hat builtins umbenannt worden, um einige dieser Verwirrung zu vermeiden.

+0

Große Antwort, vielen Dank. Weißt du etwas über Python 3? – santiagobasulto

+8

Wie andere Antworten haben gesagt, es für Python 3 das gleiche ist mit Ausnahme der '__builtin__' Modul„builtins“umbenannt wird (ohne Unterstrichen). http://docs.python.org/dev/reference/executionmodel.html – akent

6

__builtin__ ist ein Modul, um die integrierten Funktionen und Arten enthält. Die Tatsache, dass ein Name __builtins__ verfügbar ist, der die gleichen Dinge enthält, ist ein Implementierungsdetail. Mit anderen Worten, wenn Sie einen von ihnen verwenden müssen, tun Sie import __builtin__ und verwenden Sie dann __builtin__. Siehe the documentation.

17

Sie sollten __builtin__ in Ihren Programmen verwenden (in den seltenen Fällen, in denen Sie es brauchen), weil __builtins__ ein Implementierungsdetail von CPython ist.Es kann entweder identisch sein __builtin__ oder zu __builtin__.__dict__, je nach Kontext. Wie the documentation sagt:

Die meisten Module haben den Namen __builtins__ (man beachte das ‚s‘) im Rahmen ihrer Globals zur Verfügung gestellt. Der Wert von __builtins__ ist normalerweise entweder dieses Modul oder der Wert dieses Attributs __dict__ Modulen. Da dies ein Implementierungsdetail ist, kann es nicht durch alternative Implementierungen von Python verwendet werden.

In Python 3 __builtin__ hat builtins umbenannt wurde, und __builtins__ gleich bleibt (so sollten Sie nur verwenden builtins in Python 3).

Guido wollte __builtin__ und __builtins__ vereinen, wie Sie here („Mit __builtins__ und __builtin__ beide ist eindeutig eine schlechte Idee.“) Sehen können, aber anscheinend nichts daraus.

Anscheinend ist die Verwendung von __builtins__ für die Leistung - es gibt direkten Zugriff auf __builtin__.__dict__, wenn in einem Nicht-Hauptmodul verwendet wird, und entfernt daher eine Ebene der Indirektion.

1

Sie können diese verstehen wie Code folgen. wenn CPython gestartet wird, CPython Last __builtin__ Module in den globalen Namensraum

Import __builtin__ als __builtins__

Verwandte Themen