summaryrefslogtreecommitdiffstats
path: root/Doc/tutorial/modules.rst
diff options
context:
space:
mode:
authorSandro Tosi <sandro.tosi@gmail.com>2012-01-19 10:29:26 (GMT)
committerSandro Tosi <sandro.tosi@gmail.com>2012-01-19 10:29:26 (GMT)
commitf0229aa51cd089076a1ea4a9a09689831cea012f (patch)
tree4ba4fc6ebb631264d33b3938206128456e0cf86f /Doc/tutorial/modules.rst
parent972cfb9169bdf7fa6c9758a5c49659429c84b5a8 (diff)
downloadcpython-f0229aa51cd089076a1ea4a9a09689831cea012f.zip
cpython-f0229aa51cd089076a1ea4a9a09689831cea012f.tar.gz
cpython-f0229aa51cd089076a1ea4a9a09689831cea012f.tar.bz2
Issue #11948: clarify modules search path
Diffstat (limited to 'Doc/tutorial/modules.rst')
-rw-r--r--Doc/tutorial/modules.rst34
1 files changed, 16 insertions, 18 deletions
diff --git a/Doc/tutorial/modules.rst b/Doc/tutorial/modules.rst
index 3254a80..e5adb05 100644
--- a/Doc/tutorial/modules.rst
+++ b/Doc/tutorial/modules.rst
@@ -159,24 +159,22 @@ The Module Search Path
.. index:: triple: module; search; path
-When a module named :mod:`spam` is imported, the interpreter searches for a
-file named :file:`spam.py` in the directory containing the input script and
-then in the list of directories specified by the environment variable
-:envvar:`PYTHONPATH`. This has the same syntax as the shell variable
-:envvar:`PATH`, that is, a list of directory names. When :envvar:`PYTHONPATH`
-is not set, or when the file is not found there, the search continues in an
-installation-dependent default path; on Unix, this is usually
-:file:`.:/usr/local/lib/python`.
-
-Actually, modules are searched in the list of directories given by the variable
-``sys.path`` which is initialized from the directory containing the input script
-(or the current directory), :envvar:`PYTHONPATH` and the installation- dependent
-default. This allows Python programs that know what they're doing to modify or
-replace the module search path. Note that because the directory containing the
-script being run is on the search path, it is important that the script not have
-the same name as a standard module, or Python will attempt to load the script as
-a module when that module is imported. This will generally be an error. See
-section :ref:`tut-standardmodules` for more information.
+When a module named :mod:`spam` is imported, the interpreter first searches for
+a built-in module with that name. If not found, it then searches for a file
+named :file:`spam.py` in a list of directories given by the variable
+:data:`sys.path`. :data:`sys.path` is initialized from these locations:
+
+* the directory containing the input script (or the current directory).
+* :envvar:`PYTHONPATH` (a list of directory names, with the same syntax as the
+ shell variable :envvar:`PATH`).
+* the installation-dependent default.
+
+After initialization, Python programs can modify :data:`sys.path`. The
+directory containing the script being run is placed at the beginning of the
+search path, ahead of the standard library path. This means that scripts in that
+directory will be loaded instead of modules of the same name in the library
+directory. This is an error unless the replacement is intended. See section
+:ref:`tut-standardmodules` for more information.
.. %
Do we need stuff on zip files etc. ? DUBOIS