| |
| :mod:`site` --- Site-specific configuration hook |
| ================================================ |
| |
| .. module:: site |
| :synopsis: A standard way to reference site-specific modules. |
| |
| |
| **This module is automatically imported during initialization.** The automatic |
| import can be suppressed using the interpreter's :option:`-S` option. |
| |
| .. index:: triple: module; search; path |
| |
| Importing this module will append site-specific paths to the module search path. |
| |
| .. index:: |
| pair: site-python; directory |
| pair: site-packages; directory |
| |
| It starts by constructing up to four directories from a head and a tail part. |
| For the head part, it uses ``sys.prefix`` and ``sys.exec_prefix``; empty heads |
| are skipped. For the tail part, it uses the empty string and then |
| :file:`lib/site-packages` (on Windows) or |
| :file:`lib/python|version|/site-packages` and then :file:`lib/site-python` (on |
| Unix and Macintosh). For each of the distinct head-tail combinations, it sees |
| if it refers to an existing directory, and if so, adds it to ``sys.path`` and |
| also inspects the newly added path for configuration files. |
| |
| A path configuration file is a file whose name has the form :file:`package.pth` |
| and exists in one of the four directories mentioned above; its contents are |
| additional items (one per line) to be added to ``sys.path``. Non-existing items |
| are never added to ``sys.path``, but no check is made that the item refers to a |
| directory (rather than a file). No item is added to ``sys.path`` more than |
| once. Blank lines and lines beginning with ``#`` are skipped. Lines starting |
| with ``import`` (followed by space or tab) are executed. |
| |
| .. versionchanged:: 2.6 |
| A space or tab is now required after the import keyword. |
| |
| .. index:: |
| single: package |
| triple: path; configuration; file |
| |
| For example, suppose ``sys.prefix`` and ``sys.exec_prefix`` are set to |
| :file:`/usr/local`. The Python X.Y library is then installed in |
| :file:`/usr/local/lib/python{X.Y}` (where only the first three characters of |
| ``sys.version`` are used to form the installation path name). Suppose this has |
| a subdirectory :file:`/usr/local/lib/python{X.Y}/site-packages` with three |
| subsubdirectories, :file:`foo`, :file:`bar` and :file:`spam`, and two path |
| configuration files, :file:`foo.pth` and :file:`bar.pth`. Assume |
| :file:`foo.pth` contains the following:: |
| |
| # foo package configuration |
| |
| foo |
| bar |
| bletch |
| |
| and :file:`bar.pth` contains:: |
| |
| # bar package configuration |
| |
| bar |
| |
| Then the following directories are added to ``sys.path``, in this order:: |
| |
| /usr/local/lib/python2.3/site-packages/bar |
| /usr/local/lib/python2.3/site-packages/foo |
| |
| Note that :file:`bletch` is omitted because it doesn't exist; the :file:`bar` |
| directory precedes the :file:`foo` directory because :file:`bar.pth` comes |
| alphabetically before :file:`foo.pth`; and :file:`spam` is omitted because it is |
| not mentioned in either path configuration file. |
| |
| .. index:: module: sitecustomize |
| |
| After these path manipulations, an attempt is made to import a module named |
| :mod:`sitecustomize`, which can perform arbitrary site-specific customizations. |
| If this import fails with an :exc:`ImportError` exception, it is silently |
| ignored. |
| |
| .. index:: module: sitecustomize |
| |
| Note that for some non-Unix systems, ``sys.prefix`` and ``sys.exec_prefix`` are |
| empty, and the path manipulations are skipped; however the import of |
| :mod:`sitecustomize` is still attempted. |
| |