diff options
author | Barry Warsaw <barry@python.org> | 2015-04-22 22:29:16 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2015-04-22 22:29:16 (GMT) |
commit | 2097f53ec39f5214e2f2739aa508e11d15df283e (patch) | |
tree | 113730b57ca964139b5ea9e723f0beee633820f7 /Doc/reference/import.rst | |
parent | 34e006031aac2c2263cef382c55a2e38b2d1b054 (diff) | |
download | cpython-2097f53ec39f5214e2f2739aa508e11d15df283e.zip cpython-2097f53ec39f5214e2f2739aa508e11d15df283e.tar.gz cpython-2097f53ec39f5214e2f2739aa508e11d15df283e.tar.bz2 |
Issue #24029: Document the name binding behavior for submodule imports.
Diffstat (limited to 'Doc/reference/import.rst')
-rw-r--r-- | Doc/reference/import.rst | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/Doc/reference/import.rst b/Doc/reference/import.rst index e9b7e53..7966bc5 100644 --- a/Doc/reference/import.rst +++ b/Doc/reference/import.rst @@ -461,6 +461,41 @@ import machinery will create the new module itself. into :data:`sys.modules`, but it must remove **only** the failing module, and only if the loader itself has loaded it explicitly. +Submodules +---------- + +When a submodule is loaded using any mechanism (e.g. ``importlib`` APIs, the +``import`` or ``import-from`` statements, or built-in ``__import__()``) a +binding is placed in the parent module's namespace to the submodule object. +For example, if package ``spam`` has a submodule ``foo``, after importing +``spam.foo``, ``spam`` will have an attribute ``foo`` which is bound to the +submodule. Let's say you have the following directory structure:: + + spam/ + __init__.py + foo.py + bar.py + +and ``spam/__init__.py`` has the following lines in it:: + + from .foo import Foo + from .bar import Bar + +then executing the following puts a name binding to ``foo`` and ``bar`` in the +``spam`` module:: + + >>> import spam + >>> spam.foo + <module 'spam.foo' from '/tmp/imports/spam/foo.py'> + >>> spam.bar + <module 'spam.bar' from '/tmp/imports/spam/bar.py'> + +Given Python's familiar name binding rules this might seem surprising, but +it's actually a fundamental feature of the import system. The invariant +holding is that if you have ``sys.modules['spam']`` and +``sys.modules['spam.foo']`` (as you would after the above import), the latter +must appear as the ``foo`` attribute of the former. + Module spec ----------- |