blob: 579571aca59c99759e06a61a41b40ddc2b46fe4b [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001:mod:`site` --- Site-specific configuration hook
2================================================
3
4.. module:: site
Éric Araujode4f05b2011-08-06 01:51:07 +02005 :synopsis: Module responsible for site-specific configuration.
Georg Brandl116aa622007-08-15 14:28:22 +00006
Raymond Hettinger469271d2011-01-27 20:38:46 +00007**Source code:** :source:`Lib/site.py`
8
9--------------
Georg Brandl116aa622007-08-15 14:28:22 +000010
Éric Araujode4f05b2011-08-06 01:51:07 +020011.. highlightlang:: none
12
Georg Brandl116aa622007-08-15 14:28:22 +000013**This module is automatically imported during initialization.** The automatic
14import can be suppressed using the interpreter's :option:`-S` option.
15
16.. index:: triple: module; search; path
17
Éric Araujode4f05b2011-08-06 01:51:07 +020018Importing this module will append site-specific paths to the module search path
19and add a few builtins.
Georg Brandl116aa622007-08-15 14:28:22 +000020
21.. index::
22 pair: site-python; directory
23 pair: site-packages; directory
24
25It starts by constructing up to four directories from a head and a tail part.
26For the head part, it uses ``sys.prefix`` and ``sys.exec_prefix``; empty heads
27are skipped. For the tail part, it uses the empty string and then
28:file:`lib/site-packages` (on Windows) or
Ezio Melotti26e58782012-09-17 08:59:36 +020029:file:`lib/python{X.Y}/site-packages` and then :file:`lib/site-python` (on
Georg Brandl116aa622007-08-15 14:28:22 +000030Unix and Macintosh). For each of the distinct head-tail combinations, it sees
31if it refers to an existing directory, and if so, adds it to ``sys.path`` and
32also inspects the newly added path for configuration files.
33
Éric Araujode4f05b2011-08-06 01:51:07 +020034A path configuration file is a file whose name has the form :file:`{name}.pth`
Georg Brandl116aa622007-08-15 14:28:22 +000035and exists in one of the four directories mentioned above; its contents are
36additional items (one per line) to be added to ``sys.path``. Non-existing items
Éric Araujode4f05b2011-08-06 01:51:07 +020037are never added to ``sys.path``, and no check is made that the item refers to a
38directory rather than a file. No item is added to ``sys.path`` more than
Georg Brandl116aa622007-08-15 14:28:22 +000039once. Blank lines and lines beginning with ``#`` are skipped. Lines starting
40with ``import`` (followed by space or tab) are executed.
41
Georg Brandl116aa622007-08-15 14:28:22 +000042.. index::
43 single: package
44 triple: path; configuration; file
45
46For example, suppose ``sys.prefix`` and ``sys.exec_prefix`` are set to
47:file:`/usr/local`. The Python X.Y library is then installed in
Éric Araujode4f05b2011-08-06 01:51:07 +020048:file:`/usr/local/lib/python{X.Y}`. Suppose this has
Georg Brandl116aa622007-08-15 14:28:22 +000049a subdirectory :file:`/usr/local/lib/python{X.Y}/site-packages` with three
50subsubdirectories, :file:`foo`, :file:`bar` and :file:`spam`, and two path
51configuration files, :file:`foo.pth` and :file:`bar.pth`. Assume
52:file:`foo.pth` contains the following::
53
54 # foo package configuration
55
56 foo
57 bar
58 bletch
59
60and :file:`bar.pth` contains::
61
62 # bar package configuration
63
64 bar
65
Benjamin Petersone9bbc8b2008-09-28 02:06:32 +000066Then the following version-specific directories are added to
67``sys.path``, in this order::
Georg Brandl116aa622007-08-15 14:28:22 +000068
Benjamin Petersone9bbc8b2008-09-28 02:06:32 +000069 /usr/local/lib/pythonX.Y/site-packages/bar
70 /usr/local/lib/pythonX.Y/site-packages/foo
Georg Brandl116aa622007-08-15 14:28:22 +000071
72Note that :file:`bletch` is omitted because it doesn't exist; the :file:`bar`
73directory precedes the :file:`foo` directory because :file:`bar.pth` comes
74alphabetically before :file:`foo.pth`; and :file:`spam` is omitted because it is
75not mentioned in either path configuration file.
76
77.. index:: module: sitecustomize
78
79After these path manipulations, an attempt is made to import a module named
80:mod:`sitecustomize`, which can perform arbitrary site-specific customizations.
Éric Araujode4f05b2011-08-06 01:51:07 +020081It is typically created by a system administrator in the site-packages
82directory. If this import fails with an :exc:`ImportError` exception, it is
83silently ignored.
Georg Brandl116aa622007-08-15 14:28:22 +000084
Éric Araujode4f05b2011-08-06 01:51:07 +020085.. index:: module: usercustomize
86
87After this, an attempt is made to import a module named :mod:`usercustomize`,
88which can perform arbitrary user-specific customizations, if
89:data:`ENABLE_USER_SITE` is true. This file is intended to be created in the
90user site-packages directory (see below), which is part of ``sys.path`` unless
91disabled by :option:`-s`. An :exc:`ImportError` will be silently ignored.
Georg Brandl116aa622007-08-15 14:28:22 +000092
93Note that for some non-Unix systems, ``sys.prefix`` and ``sys.exec_prefix`` are
94empty, and the path manipulations are skipped; however the import of
Éric Araujode4f05b2011-08-06 01:51:07 +020095:mod:`sitecustomize` and :mod:`usercustomize` is still attempted.
Georg Brandl116aa622007-08-15 14:28:22 +000096
Christian Heimes8dc226f2008-05-06 23:45:46 +000097
98.. data:: PREFIXES
99
Éric Araujode4f05b2011-08-06 01:51:07 +0200100 A list of prefixes for site-packages directories.
Christian Heimes8dc226f2008-05-06 23:45:46 +0000101
Christian Heimes8dc226f2008-05-06 23:45:46 +0000102
103.. data:: ENABLE_USER_SITE
104
Éric Araujode4f05b2011-08-06 01:51:07 +0200105 Flag showing the status of the user site-packages directory. ``True`` means
106 that it is enabled and was added to ``sys.path``. ``False`` means that it
107 was disabled by user request (with :option:`-s` or
108 :envvar:`PYTHONNOUSERSITE`). ``None`` means it was disabled for security
109 reasons (mismatch between user or group id and effective id) or by an
110 administrator.
Christian Heimes8dc226f2008-05-06 23:45:46 +0000111
Christian Heimes8dc226f2008-05-06 23:45:46 +0000112
113.. data:: USER_SITE
114
Éric Araujode4f05b2011-08-06 01:51:07 +0200115 Path to the user site-packages for the running Python. Can be ``None`` if
116 :func:`getusersitepackages` hasn't been called yet. Default value is
117 :file:`~/.local/lib/python{X.Y}/site-packages` for UNIX and non-framework Mac
118 OS X builds, :file:`~/Library/Python/{X.Y}/lib/python/site-packages` for Mac
119 framework builds, and :file:`{%APPDATA%}\\Python\\Python{XY}\\site-packages`
120 on Windows. This directory is a site directory, which means that
121 :file:`.pth` files in it will be processed.
Christian Heimes8dc226f2008-05-06 23:45:46 +0000122
Christian Heimes8dc226f2008-05-06 23:45:46 +0000123
124.. data:: USER_BASE
125
Éric Araujode4f05b2011-08-06 01:51:07 +0200126 Path to the base directory for the user site-packages. Can be ``None`` if
127 :func:`getuserbase` hasn't been called yet. Default value is
128 :file:`~/.local` for UNIX and Mac OS X non-framework builds,
129 :file:`~/Library/Python/{X.Y}` for Mac framework builds, and
130 :file:`{%APPDATA%}\\Python` for Windows. This value is used by Distutils to
131 compute the installation directories for scripts, data files, Python modules,
Éric Araujo6ef038e2011-08-06 16:30:42 +0200132 etc. for the :ref:`user installation scheme <inst-alt-install-user>`. See
133 also :envvar:`PYTHONUSERBASE`.
Christian Heimes8dc226f2008-05-06 23:45:46 +0000134
Christian Heimes8dc226f2008-05-06 23:45:46 +0000135
136.. function:: addsitedir(sitedir, known_paths=None)
137
Éric Araujo6ef038e2011-08-06 16:30:42 +0200138 Add a directory to sys.path and process its :file:`.pth` files. Typically
139 used in :mod:`sitecustomize` or :mod:`usercustomize` (see above).
Éric Araujode4f05b2011-08-06 01:51:07 +0200140
Christian Heimes8dc226f2008-05-06 23:45:46 +0000141
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000142.. function:: getsitepackages()
143
Éric Araujode4f05b2011-08-06 01:51:07 +0200144 Return a list containing all global site-packages directories (and possibly
145 site-python).
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000146
Mark Dickinson574b1d62009-10-01 20:20:09 +0000147 .. versionadded:: 3.2
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000148
Éric Araujode4f05b2011-08-06 01:51:07 +0200149
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000150.. function:: getuserbase()
151
Éric Araujode4f05b2011-08-06 01:51:07 +0200152 Return the path of the user base directory, :data:`USER_BASE`. If it is not
153 initialized yet, this function will also set it, respecting
154 :envvar:`PYTHONUSERBASE`.
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000155
Mark Dickinson574b1d62009-10-01 20:20:09 +0000156 .. versionadded:: 3.2
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000157
Éric Araujode4f05b2011-08-06 01:51:07 +0200158
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000159.. function:: getusersitepackages()
160
Éric Araujode4f05b2011-08-06 01:51:07 +0200161 Return the path of the user-specific site-packages directory,
162 :data:`USER_SITE`. If it is not initialized yet, this function will also set
163 it, respecting :envvar:`PYTHONNOUSERSITE` and :data:`USER_BASE`.
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000164
Mark Dickinson574b1d62009-10-01 20:20:09 +0000165 .. versionadded:: 3.2
Christian Heimes8dc226f2008-05-06 23:45:46 +0000166
Tarek Ziadé4a608c02009-08-20 21:28:05 +0000167
Éric Araujode4f05b2011-08-06 01:51:07 +0200168The :mod:`site` module also provides a way to get the user directories from the
169command line:
170
171.. code-block:: sh
172
173 $ python3 -m site --user-site
174 /home/user/.local/lib/python3.3/site-packages
175
176.. program:: site
177
178If it is called without arguments, it will print the contents of
179:data:`sys.path` on the standard output, followed by the value of
180:data:`USER_BASE` and whether the directory exists, then the same thing for
181:data:`USER_SITE`, and finally the value of :data:`ENABLE_USER_SITE`.
182
183.. cmdoption:: --user-base
184
185 Print the path to the user base directory.
186
187.. cmdoption:: --user-site
188
189 Print the path to the user site-packages directory.
190
191If both options are given, user base and user site will be printed (always in
192this order), separated by :data:`os.pathsep`.
193
194If any option is given, the script will exit with one of these values: ``O`` if
195the user site-packages directory is enabled, ``1`` if it was disabled by the
196user, ``2`` if it is disabled for security reasons or by an administrator, and a
197value greater than 2 if there is an error.
198
199.. seealso::
200
201 :pep:`370` -- Per user site-packages directory