2024-05-08 16:34:40 -03:00
|
|
|
:mod:`!sysconfig` --- Provide access to Python's configuration information
|
|
|
|
==========================================================================
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
.. module:: sysconfig
|
|
|
|
:synopsis: Python's configuration information
|
2016-06-11 16:02:54 -03:00
|
|
|
|
2011-08-18 19:49:18 -03:00
|
|
|
.. moduleauthor:: Tarek Ziadé <tarek@ziade.org>
|
|
|
|
.. sectionauthor:: Tarek Ziadé <tarek@ziade.org>
|
|
|
|
|
2011-01-26 21:20:32 -04:00
|
|
|
.. versionadded:: 3.2
|
|
|
|
|
2023-10-16 08:27:12 -03:00
|
|
|
**Source code:** :source:`Lib/sysconfig`
|
2011-08-18 19:49:18 -03:00
|
|
|
|
2016-06-11 16:02:54 -03:00
|
|
|
.. index::
|
|
|
|
single: configuration information
|
|
|
|
|
2011-01-26 21:20:32 -04:00
|
|
|
--------------
|
|
|
|
|
2010-02-02 19:17:47 -04:00
|
|
|
The :mod:`sysconfig` module provides access to Python's configuration
|
2010-02-11 16:47:18 -04:00
|
|
|
information like the list of installation paths and the configuration variables
|
|
|
|
relevant for the current platform.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2023-10-02 07:40:03 -03:00
|
|
|
|
2010-02-02 19:17:47 -04:00
|
|
|
Configuration variables
|
|
|
|
-----------------------
|
|
|
|
|
Merged revisions 80605-80609,80642-80646,80651-80652,80674,80684-80686,80748,80852,80854,80870,80872-80873,80907,80915-80916,80951-80952,80976-80977,80985,81038-81040,81042,81053,81070,81104-81105,81114,81125,81245,81285,81402,81463,81516,81562-81563,81567,81593,81635,81680-81681,81684,81801,81888,81931-81933,81939-81942,81963,81984,81991,82120,82188,82264-82267 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r80605 | andrew.kuchling | 2010-04-28 19:22:16 -0500 (Wed, 28 Apr 2010) | 1 line
Add various items
........
r80606 | andrew.kuchling | 2010-04-28 20:44:30 -0500 (Wed, 28 Apr 2010) | 6 lines
Fix doubled 'the'.
Markup fixes to use :exc:, :option: in a few places.
(Glitch: unittest.main's -c ends up a link to the Python
interpreter's -c option. Should we skip using :option: for that
switch, or disable the auto-linking somehow?)
........
r80607 | andrew.kuchling | 2010-04-28 20:45:41 -0500 (Wed, 28 Apr 2010) | 1 line
Add various unittest items
........
r80608 | benjamin.peterson | 2010-04-28 22:18:05 -0500 (Wed, 28 Apr 2010) | 1 line
update pypy description
........
r80609 | benjamin.peterson | 2010-04-28 22:30:59 -0500 (Wed, 28 Apr 2010) | 1 line
update pypy url
........
r80642 | andrew.kuchling | 2010-04-29 19:49:09 -0500 (Thu, 29 Apr 2010) | 1 line
Always add space after RFC; reword paragraph
........
r80643 | andrew.kuchling | 2010-04-29 19:52:31 -0500 (Thu, 29 Apr 2010) | 6 lines
Reword paragraph to make its meaning clearer.
Antoine Pitrou: is my version of the paragraph still correct?
R. David Murray: is this more understandable than the previous version?
........
r80644 | andrew.kuchling | 2010-04-29 20:02:15 -0500 (Thu, 29 Apr 2010) | 1 line
Fix typos
........
r80645 | andrew.kuchling | 2010-04-29 20:32:47 -0500 (Thu, 29 Apr 2010) | 1 line
Markup fix; clarify by adding 'in that order'
........
r80646 | andrew.kuchling | 2010-04-29 20:33:40 -0500 (Thu, 29 Apr 2010) | 1 line
Add various items; rearrange unittest section a bit
........
r80651 | andrew.kuchling | 2010-04-30 08:46:55 -0500 (Fri, 30 Apr 2010) | 1 line
Minor grammar re-wording
........
r80652 | andrew.kuchling | 2010-04-30 08:47:34 -0500 (Fri, 30 Apr 2010) | 1 line
Add item
........
r80674 | andrew.kuchling | 2010-04-30 20:19:16 -0500 (Fri, 30 Apr 2010) | 1 line
Add various items
........
r80684 | andrew.kuchling | 2010-05-01 07:05:52 -0500 (Sat, 01 May 2010) | 1 line
Minor grammar fix
........
r80685 | andrew.kuchling | 2010-05-01 07:06:51 -0500 (Sat, 01 May 2010) | 1 line
Describe memoryview
........
r80686 | antoine.pitrou | 2010-05-01 07:16:39 -0500 (Sat, 01 May 2010) | 4 lines
Fix attribution. Travis didn't do much and he did a bad work.
(yes, this is a sensitive subject, sorry)
........
r80748 | andrew.kuchling | 2010-05-03 20:24:22 -0500 (Mon, 03 May 2010) | 1 line
Add some more items; the urlparse change is added twice
........
r80852 | andrew.kuchling | 2010-05-05 20:09:47 -0500 (Wed, 05 May 2010) | 1 line
Reword paragraph; fix filename, which should be pyconfig.h
........
r80854 | andrew.kuchling | 2010-05-05 20:10:56 -0500 (Wed, 05 May 2010) | 1 line
Add various items
........
r80870 | andrew.kuchling | 2010-05-06 09:14:09 -0500 (Thu, 06 May 2010) | 1 line
Describe ElementTree 1.3; rearrange new-module sections; describe dict views as sets; small edits and items
........
r80872 | andrew.kuchling | 2010-05-06 12:21:59 -0500 (Thu, 06 May 2010) | 1 line
Add 2 items; record ideas for two initial sections; clarify wording
........
r80873 | andrew.kuchling | 2010-05-06 12:27:57 -0500 (Thu, 06 May 2010) | 1 line
Change section title; point to unittest2
........
r80907 | andrew.kuchling | 2010-05-06 20:45:14 -0500 (Thu, 06 May 2010) | 1 line
Add a new section on the development plan; add an item
........
r80915 | antoine.pitrou | 2010-05-07 05:15:51 -0500 (Fri, 07 May 2010) | 3 lines
Fix some markup and a class name. Also, wrap a long line.
........
r80916 | andrew.kuchling | 2010-05-07 06:30:47 -0500 (Fri, 07 May 2010) | 1 line
Re-word text
........
r80951 | andrew.kuchling | 2010-05-07 20:15:26 -0500 (Fri, 07 May 2010) | 1 line
Add two items
........
r80952 | andrew.kuchling | 2010-05-07 20:35:55 -0500 (Fri, 07 May 2010) | 1 line
Get accents correct
........
r80976 | andrew.kuchling | 2010-05-08 08:28:03 -0500 (Sat, 08 May 2010) | 1 line
Add logging.dictConfig example; give up on writing a Ttk example
........
r80977 | andrew.kuchling | 2010-05-08 08:29:46 -0500 (Sat, 08 May 2010) | 1 line
Markup fixes
........
r80985 | andrew.kuchling | 2010-05-08 10:39:46 -0500 (Sat, 08 May 2010) | 7 lines
Write summary of the 2.7 release; rewrite the future section some more;
mention PYTHONWARNINGS env. var; tweak some examples for readability.
And with this commit, the "What's New" is done... except for a
complete read-through to polish the text, and fixing any reported errors,
but those tasks can easily wait until after beta2.
........
r81038 | benjamin.peterson | 2010-05-09 16:09:40 -0500 (Sun, 09 May 2010) | 1 line
finish clause
........
r81039 | andrew.kuchling | 2010-05-10 09:18:27 -0500 (Mon, 10 May 2010) | 1 line
Markup fix; re-word a sentence
........
r81040 | andrew.kuchling | 2010-05-10 09:20:12 -0500 (Mon, 10 May 2010) | 1 line
Use title case
........
r81042 | andrew.kuchling | 2010-05-10 10:03:35 -0500 (Mon, 10 May 2010) | 1 line
Link to unittest2 article
........
r81053 | florent.xicluna | 2010-05-10 14:59:22 -0500 (Mon, 10 May 2010) | 2 lines
Add a link on maketrans().
........
r81070 | andrew.kuchling | 2010-05-10 18:13:41 -0500 (Mon, 10 May 2010) | 1 line
Fix typo
........
r81104 | andrew.kuchling | 2010-05-11 19:38:44 -0500 (Tue, 11 May 2010) | 1 line
Revision pass: lots of edits, typo fixes, rearrangements
........
r81105 | andrew.kuchling | 2010-05-11 19:40:47 -0500 (Tue, 11 May 2010) | 1 line
Let's call this done
........
r81114 | andrew.kuchling | 2010-05-12 08:56:07 -0500 (Wed, 12 May 2010) | 1 line
Grammar fix
........
r81125 | andrew.kuchling | 2010-05-12 13:56:48 -0500 (Wed, 12 May 2010) | 1 line
#8696: add documentation for logging.config.dictConfig (PEP 391)
........
r81245 | andrew.kuchling | 2010-05-16 18:31:16 -0500 (Sun, 16 May 2010) | 1 line
Add cross-reference to later section
........
r81285 | vinay.sajip | 2010-05-18 03:16:27 -0500 (Tue, 18 May 2010) | 1 line
Fixed minor typo in ReST markup.
........
r81402 | vinay.sajip | 2010-05-21 12:41:34 -0500 (Fri, 21 May 2010) | 1 line
Updated logging documentation with more dictConfig information.
........
r81463 | georg.brandl | 2010-05-22 03:17:23 -0500 (Sat, 22 May 2010) | 1 line
#8785: less confusing description of regex.find*.
........
r81516 | andrew.kuchling | 2010-05-25 08:34:08 -0500 (Tue, 25 May 2010) | 1 line
Add three items
........
r81562 | andrew.kuchling | 2010-05-27 08:22:53 -0500 (Thu, 27 May 2010) | 1 line
Rewrite wxWidgets section
........
r81563 | andrew.kuchling | 2010-05-27 08:30:09 -0500 (Thu, 27 May 2010) | 1 line
Remove top-level 'General Questions' section, pushing up the questions it contains
........
r81567 | andrew.kuchling | 2010-05-27 16:29:59 -0500 (Thu, 27 May 2010) | 1 line
Add item
........
r81593 | georg.brandl | 2010-05-29 03:46:18 -0500 (Sat, 29 May 2010) | 1 line
#8616: add new turtle demo "nim".
........
r81635 | georg.brandl | 2010-06-01 02:25:23 -0500 (Tue, 01 Jun 2010) | 1 line
Put docs for RegexObject.search() before RegexObject.match() to mirror re.search() and re.match() order.
........
r81680 | vinay.sajip | 2010-06-03 17:34:42 -0500 (Thu, 03 Jun 2010) | 1 line
Issue #8890: Documentation changed to avoid reference to temporary files.
........
r81681 | sean.reifschneider | 2010-06-03 20:51:26 -0500 (Thu, 03 Jun 2010) | 2 lines
Issue8810: Clearing up docstring for tzinfo.utcoffset.
........
r81684 | vinay.sajip | 2010-06-04 08:41:02 -0500 (Fri, 04 Jun 2010) | 1 line
Issue #8890: Documentation changed to avoid reference to temporary files - other cases covered.
........
r81801 | andrew.kuchling | 2010-06-07 08:38:40 -0500 (Mon, 07 Jun 2010) | 1 line
#8875: Remove duplicated paragraph
........
r81888 | andrew.kuchling | 2010-06-10 20:54:58 -0500 (Thu, 10 Jun 2010) | 1 line
Add a few more items
........
r81931 | georg.brandl | 2010-06-12 01:26:54 -0500 (Sat, 12 Jun 2010) | 1 line
Fix punctuation.
........
r81932 | georg.brandl | 2010-06-12 01:28:58 -0500 (Sat, 12 Jun 2010) | 1 line
Document that an existing directory raises in mkdir().
........
r81933 | georg.brandl | 2010-06-12 01:45:33 -0500 (Sat, 12 Jun 2010) | 1 line
Update version in README.
........
r81939 | georg.brandl | 2010-06-12 04:45:01 -0500 (Sat, 12 Jun 2010) | 1 line
Use newer toctree syntax.
........
r81940 | georg.brandl | 2010-06-12 04:45:28 -0500 (Sat, 12 Jun 2010) | 1 line
Add document on how to build.
........
r81941 | georg.brandl | 2010-06-12 04:45:58 -0500 (Sat, 12 Jun 2010) | 1 line
Fix gratuitous indentation.
........
r81942 | georg.brandl | 2010-06-12 04:46:03 -0500 (Sat, 12 Jun 2010) | 1 line
Update README.
........
r81963 | andrew.kuchling | 2010-06-12 15:00:55 -0500 (Sat, 12 Jun 2010) | 1 line
Grammar fix
........
r81984 | georg.brandl | 2010-06-14 10:58:39 -0500 (Mon, 14 Jun 2010) | 1 line
#8993: fix reference.
........
r81991 | andrew.kuchling | 2010-06-14 19:38:58 -0500 (Mon, 14 Jun 2010) | 1 line
Add another bunch of items
........
r82120 | andrew.kuchling | 2010-06-20 16:45:45 -0500 (Sun, 20 Jun 2010) | 1 line
Note that Python 3.x isn't covered; add forward ref. for UTF-8; note error in 2.5 and up
........
r82188 | benjamin.peterson | 2010-06-23 19:02:46 -0500 (Wed, 23 Jun 2010) | 1 line
remove reverted changed
........
r82264 | georg.brandl | 2010-06-27 05:47:47 -0500 (Sun, 27 Jun 2010) | 1 line
Confusing punctuation.
........
r82265 | georg.brandl | 2010-06-27 05:49:23 -0500 (Sun, 27 Jun 2010) | 1 line
Use designated syntax for optional grammar element.
........
r82266 | georg.brandl | 2010-06-27 05:51:44 -0500 (Sun, 27 Jun 2010) | 1 line
Fix URL.
........
r82267 | georg.brandl | 2010-06-27 05:55:38 -0500 (Sun, 27 Jun 2010) | 1 line
Two typos.
........
2010-06-27 19:32:30 -03:00
|
|
|
A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h`
|
|
|
|
header file that are necessary to build both the Python binary itself and
|
2022-07-25 10:50:46 -03:00
|
|
|
third-party C extensions compiled using ``setuptools``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
:mod:`sysconfig` puts all variables found in these files in a dictionary that
|
|
|
|
can be accessed using :func:`get_config_vars` or :func:`get_config_var`.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
Notice that on Windows, it's a much smaller set.
|
|
|
|
|
2020-12-16 21:37:28 -04:00
|
|
|
.. function:: get_config_vars(*args)
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
With no arguments, return a dictionary of all configuration variables
|
|
|
|
relevant for the current platform.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
With arguments, return a list of values that result from looking up each
|
|
|
|
argument in the configuration variable dictionary.
|
|
|
|
|
|
|
|
For each argument, if the value is not found, return ``None``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
|
|
|
|
.. function:: get_config_var(name)
|
|
|
|
|
|
|
|
Return the value of a single variable *name*. Equivalent to
|
2010-02-11 16:47:18 -04:00
|
|
|
``get_config_vars().get(name)``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
If *name* is not found, return ``None``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
Example of usage::
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
>>> import sysconfig
|
|
|
|
>>> sysconfig.get_config_var('Py_ENABLE_SHARED')
|
|
|
|
0
|
|
|
|
>>> sysconfig.get_config_var('LIBDIR')
|
|
|
|
'/usr/local/lib'
|
|
|
|
>>> sysconfig.get_config_vars('AR', 'CXX')
|
|
|
|
['ar', 'g++']
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2023-10-02 07:40:03 -03:00
|
|
|
|
2021-11-18 16:08:24 -04:00
|
|
|
.. _installation_paths:
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
Installation paths
|
|
|
|
------------------
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
Python uses an installation scheme that differs depending on the platform and on
|
|
|
|
the installation options. These schemes are stored in :mod:`sysconfig` under
|
|
|
|
unique identifiers based on the value returned by :const:`os.name`.
|
2023-10-02 07:40:03 -03:00
|
|
|
The schemes are used by package installers to determine where to copy files to.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2022-03-18 06:53:29 -03:00
|
|
|
Python currently supports nine schemes:
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2021-09-22 14:33:36 -03:00
|
|
|
- *posix_prefix*: scheme for POSIX platforms like Linux or macOS. This is
|
2010-02-11 16:47:18 -04:00
|
|
|
the default scheme used when Python or a component is installed.
|
2023-10-02 07:40:03 -03:00
|
|
|
- *posix_home*: scheme for POSIX platforms, when the *home* option is used.
|
|
|
|
This scheme defines paths located under a specific home prefix.
|
|
|
|
- *posix_user*: scheme for POSIX platforms, when the *user* option is used.
|
|
|
|
This scheme defines paths located under the user's home directory
|
|
|
|
(:const:`site.USER_BASE`).
|
2022-03-18 06:53:29 -03:00
|
|
|
- *posix_venv*: scheme for :mod:`Python virtual environments <venv>` on POSIX
|
2023-08-20 05:11:39 -03:00
|
|
|
platforms; by default it is the same as *posix_prefix*.
|
2023-10-02 07:40:03 -03:00
|
|
|
- *nt*: scheme for Windows.
|
|
|
|
This is the default scheme used when Python or a component is installed.
|
|
|
|
- *nt_user*: scheme for Windows, when the *user* option is used.
|
|
|
|
- *nt_venv*: scheme for :mod:`Python virtual environments <venv>` on Windows;
|
|
|
|
by default it is the same as *nt*.
|
2023-08-20 05:11:39 -03:00
|
|
|
- *venv*: a scheme with values from either *posix_venv* or *nt_venv* depending
|
|
|
|
on the platform Python runs on.
|
2021-11-18 16:08:24 -04:00
|
|
|
- *osx_framework_user*: scheme for macOS, when the *user* option is used.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
Each scheme is itself composed of a series of paths and each path has a unique
|
2010-02-11 16:47:18 -04:00
|
|
|
identifier. Python currently uses eight paths:
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
- *stdlib*: directory containing the standard Python library files that are not
|
|
|
|
platform-specific.
|
|
|
|
- *platstdlib*: directory containing the standard Python library files that are
|
|
|
|
platform-specific.
|
|
|
|
- *platlib*: directory for site-specific, platform-specific files.
|
2023-10-02 07:40:03 -03:00
|
|
|
- *purelib*: directory for site-specific, non-platform-specific files ('pure' Python).
|
2021-11-23 06:28:14 -04:00
|
|
|
- *include*: directory for non-platform-specific header files for
|
|
|
|
the Python C-API.
|
|
|
|
- *platinclude*: directory for platform-specific header files for
|
|
|
|
the Python C-API.
|
2010-02-11 16:47:18 -04:00
|
|
|
- *scripts*: directory for script files.
|
|
|
|
- *data*: directory for data files.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2023-10-02 07:40:03 -03:00
|
|
|
|
|
|
|
.. _sysconfig-user-scheme:
|
|
|
|
|
|
|
|
User scheme
|
|
|
|
---------------
|
|
|
|
|
|
|
|
This scheme is designed to be the most convenient solution for users that don't
|
|
|
|
have write permission to the global site-packages directory or don't want to
|
|
|
|
install into it.
|
|
|
|
|
|
|
|
Files will be installed into subdirectories of :const:`site.USER_BASE` (written
|
|
|
|
as :file:`{userbase}` hereafter). This scheme installs pure Python modules and
|
|
|
|
extension modules in the same location (also known as :const:`site.USER_SITE`).
|
|
|
|
|
|
|
|
``posix_user``
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
============== ===========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ===========================================================
|
|
|
|
*stdlib* :file:`{userbase}/lib/python{X.Y}`
|
|
|
|
*platstdlib* :file:`{userbase}/lib/python{X.Y}`
|
|
|
|
*platlib* :file:`{userbase}/lib/python{X.Y}/site-packages`
|
|
|
|
*purelib* :file:`{userbase}/lib/python{X.Y}/site-packages`
|
|
|
|
*include* :file:`{userbase}/include/python{X.Y}`
|
|
|
|
*scripts* :file:`{userbase}/bin`
|
|
|
|
*data* :file:`{userbase}`
|
|
|
|
============== ===========================================================
|
|
|
|
|
|
|
|
``nt_user``
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
============== ===========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ===========================================================
|
|
|
|
*stdlib* :file:`{userbase}\\Python{XY}`
|
|
|
|
*platstdlib* :file:`{userbase}\\Python{XY}`
|
|
|
|
*platlib* :file:`{userbase}\\Python{XY}\\site-packages`
|
|
|
|
*purelib* :file:`{userbase}\\Python{XY}\\site-packages`
|
|
|
|
*include* :file:`{userbase}\\Python{XY}\\Include`
|
|
|
|
*scripts* :file:`{userbase}\\Python{XY}\\Scripts`
|
|
|
|
*data* :file:`{userbase}`
|
|
|
|
============== ===========================================================
|
|
|
|
|
|
|
|
``osx_framework_user``
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
============== ===========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ===========================================================
|
|
|
|
*stdlib* :file:`{userbase}/lib/python`
|
|
|
|
*platstdlib* :file:`{userbase}/lib/python`
|
|
|
|
*platlib* :file:`{userbase}/lib/python/site-packages`
|
|
|
|
*purelib* :file:`{userbase}/lib/python/site-packages`
|
|
|
|
*include* :file:`{userbase}/include/python{X.Y}`
|
|
|
|
*scripts* :file:`{userbase}/bin`
|
|
|
|
*data* :file:`{userbase}`
|
|
|
|
============== ===========================================================
|
|
|
|
|
|
|
|
|
|
|
|
.. _sysconfig-home-scheme:
|
|
|
|
|
|
|
|
Home scheme
|
|
|
|
-----------
|
|
|
|
|
|
|
|
The idea behind the "home scheme" is that you build and maintain a personal
|
|
|
|
stash of Python modules. This scheme's name is derived from the idea of a
|
|
|
|
"home" directory on Unix, since it's not unusual for a Unix user to make their
|
|
|
|
home directory have a layout similar to :file:`/usr/` or :file:`/usr/local/`.
|
|
|
|
This scheme can be used by anyone, regardless of the operating system they
|
|
|
|
are installing for.
|
|
|
|
|
|
|
|
``posix_home``
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
============== ===========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ===========================================================
|
|
|
|
*stdlib* :file:`{home}/lib/python`
|
|
|
|
*platstdlib* :file:`{home}/lib/python`
|
|
|
|
*platlib* :file:`{home}/lib/python`
|
|
|
|
*purelib* :file:`{home}/lib/python`
|
|
|
|
*include* :file:`{home}/include/python`
|
|
|
|
*platinclude* :file:`{home}/include/python`
|
|
|
|
*scripts* :file:`{home}/bin`
|
|
|
|
*data* :file:`{home}`
|
|
|
|
============== ===========================================================
|
|
|
|
|
|
|
|
|
|
|
|
.. _sysconfig-prefix-scheme:
|
|
|
|
|
|
|
|
Prefix scheme
|
|
|
|
-------------
|
|
|
|
|
|
|
|
The "prefix scheme" is useful when you wish to use one Python installation to
|
|
|
|
perform the build/install (i.e., to run the setup script), but install modules
|
|
|
|
into the third-party module directory of a different Python installation (or
|
|
|
|
something that looks like a different Python installation). If this sounds a
|
|
|
|
trifle unusual, it is---that's why the user and home schemes come before. However,
|
|
|
|
there are at least two known cases where the prefix scheme will be useful.
|
|
|
|
|
|
|
|
First, consider that many Linux distributions put Python in :file:`/usr`, rather
|
|
|
|
than the more traditional :file:`/usr/local`. This is entirely appropriate,
|
|
|
|
since in those cases Python is part of "the system" rather than a local add-on.
|
|
|
|
However, if you are installing Python modules from source, you probably want
|
|
|
|
them to go in :file:`/usr/local/lib/python2.{X}` rather than
|
|
|
|
:file:`/usr/lib/python2.{X}`.
|
|
|
|
|
|
|
|
Another possibility is a network filesystem where the name used to write to a
|
|
|
|
remote directory is different from the name used to read it: for example, the
|
|
|
|
Python interpreter accessed as :file:`/usr/local/bin/python` might search for
|
|
|
|
modules in :file:`/usr/local/lib/python2.{X}`, but those modules would have to
|
|
|
|
be installed to, say, :file:`/mnt/{@server}/export/lib/python2.{X}`.
|
|
|
|
|
|
|
|
``posix_prefix``
|
|
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
============== ==========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ==========================================================
|
|
|
|
*stdlib* :file:`{prefix}/lib/python{X.Y}`
|
|
|
|
*platstdlib* :file:`{prefix}/lib/python{X.Y}`
|
|
|
|
*platlib* :file:`{prefix}/lib/python{X.Y}/site-packages`
|
|
|
|
*purelib* :file:`{prefix}/lib/python{X.Y}/site-packages`
|
|
|
|
*include* :file:`{prefix}/include/python{X.Y}`
|
|
|
|
*platinclude* :file:`{prefix}/include/python{X.Y}`
|
|
|
|
*scripts* :file:`{prefix}/bin`
|
|
|
|
*data* :file:`{prefix}`
|
|
|
|
============== ==========================================================
|
|
|
|
|
|
|
|
``nt``
|
|
|
|
^^^^^^
|
|
|
|
|
|
|
|
============== ==========================================================
|
|
|
|
Path Installation directory
|
|
|
|
============== ==========================================================
|
|
|
|
*stdlib* :file:`{prefix}\\Lib`
|
|
|
|
*platstdlib* :file:`{prefix}\\Lib`
|
|
|
|
*platlib* :file:`{prefix}\\Lib\\site-packages`
|
|
|
|
*purelib* :file:`{prefix}\\Lib\\site-packages`
|
|
|
|
*include* :file:`{prefix}\\Include`
|
|
|
|
*platinclude* :file:`{prefix}\\Include`
|
|
|
|
*scripts* :file:`{prefix}\\Scripts`
|
|
|
|
*data* :file:`{prefix}`
|
|
|
|
============== ==========================================================
|
|
|
|
|
|
|
|
|
|
|
|
Installation path functions
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
:mod:`sysconfig` provides some functions to determine these installation paths.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
.. function:: get_scheme_names()
|
|
|
|
|
|
|
|
Return a tuple containing all schemes currently supported in
|
|
|
|
:mod:`sysconfig`.
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
|
2021-04-27 05:45:55 -03:00
|
|
|
.. function:: get_default_scheme()
|
|
|
|
|
|
|
|
Return the default scheme name for the current platform.
|
|
|
|
|
2022-12-13 06:54:07 -04:00
|
|
|
.. versionadded:: 3.10
|
2021-04-27 05:45:55 -03:00
|
|
|
This function was previously named ``_get_default_scheme()`` and
|
|
|
|
considered an implementation detail.
|
|
|
|
|
2022-03-18 06:53:29 -03:00
|
|
|
.. versionchanged:: 3.11
|
|
|
|
When Python runs from a virtual environment,
|
|
|
|
the *venv* scheme is returned.
|
2021-04-27 05:45:55 -03:00
|
|
|
|
|
|
|
.. function:: get_preferred_scheme(key)
|
|
|
|
|
|
|
|
Return a preferred scheme name for an installation layout specified by *key*.
|
|
|
|
|
|
|
|
*key* must be either ``"prefix"``, ``"home"``, or ``"user"``.
|
|
|
|
|
|
|
|
The return value is a scheme name listed in :func:`get_scheme_names`. It
|
|
|
|
can be passed to :mod:`sysconfig` functions that take a *scheme* argument,
|
|
|
|
such as :func:`get_paths`.
|
|
|
|
|
|
|
|
.. versionadded:: 3.10
|
|
|
|
|
2022-03-18 06:53:29 -03:00
|
|
|
.. versionchanged:: 3.11
|
|
|
|
When Python runs from a virtual environment and ``key="prefix"``,
|
|
|
|
the *venv* scheme is returned.
|
|
|
|
|
2021-04-27 05:45:55 -03:00
|
|
|
|
|
|
|
.. function:: _get_preferred_schemes()
|
|
|
|
|
|
|
|
Return a dict containing preferred scheme names on the current platform.
|
|
|
|
Python implementers and redistributors may add their preferred schemes to
|
|
|
|
the ``_INSTALL_SCHEMES`` module-level global value, and modify this function
|
|
|
|
to return those scheme names, to e.g. provide different schemes for system
|
|
|
|
and language package managers to use, so packages installed by either do not
|
|
|
|
mix with those by the other.
|
|
|
|
|
|
|
|
End users should not use this function, but :func:`get_default_scheme` and
|
2024-08-30 08:34:09 -03:00
|
|
|
:func:`get_preferred_scheme` instead.
|
2021-04-27 05:45:55 -03:00
|
|
|
|
|
|
|
.. versionadded:: 3.10
|
|
|
|
|
|
|
|
|
2010-02-02 19:17:47 -04:00
|
|
|
.. function:: get_path_names()
|
|
|
|
|
|
|
|
Return a tuple containing all path names currently supported in
|
|
|
|
:mod:`sysconfig`.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: get_path(name, [scheme, [vars, [expand]]])
|
|
|
|
|
|
|
|
Return an installation path corresponding to the path *name*, from the
|
|
|
|
install scheme named *scheme*.
|
|
|
|
|
|
|
|
*name* has to be a value from the list returned by :func:`get_path_names`.
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
:mod:`sysconfig` stores installation paths corresponding to each path name,
|
|
|
|
for each platform, with variables to be expanded. For instance the *stdlib*
|
|
|
|
path for the *nt* scheme is: ``{base}/Lib``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
:func:`get_path` will use the variables returned by :func:`get_config_vars`
|
2010-02-11 16:47:18 -04:00
|
|
|
to expand the path. All variables have default values for each platform so
|
|
|
|
one may call this function and get the default value.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
If *scheme* is provided, it must be a value from the list returned by
|
2011-11-29 11:34:58 -04:00
|
|
|
:func:`get_scheme_names`. Otherwise, the default scheme for the current
|
2010-02-02 19:17:47 -04:00
|
|
|
platform is used.
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
If *vars* is provided, it must be a dictionary of variables that will update
|
2023-08-20 05:11:39 -03:00
|
|
|
the dictionary returned by :func:`get_config_vars`.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
If *expand* is set to ``False``, the path will not be expanded using the
|
|
|
|
variables.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2021-07-26 13:18:19 -03:00
|
|
|
If *name* is not found, raise a :exc:`KeyError`.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
|
|
|
|
.. function:: get_paths([scheme, [vars, [expand]]])
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
Return a dictionary containing all installation paths corresponding to an
|
2010-02-02 19:17:47 -04:00
|
|
|
installation scheme. See :func:`get_path` for more information.
|
|
|
|
|
|
|
|
If *scheme* is not provided, will use the default scheme for the current
|
|
|
|
platform.
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
If *vars* is provided, it must be a dictionary of variables that will
|
|
|
|
update the dictionary used to expand the paths.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2016-10-19 12:30:05 -03:00
|
|
|
If *expand* is set to false, the paths will not be expanded.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
If *scheme* is not an existing scheme, :func:`get_paths` will raise a
|
|
|
|
:exc:`KeyError`.
|
|
|
|
|
|
|
|
|
|
|
|
Other functions
|
|
|
|
---------------
|
|
|
|
|
|
|
|
.. function:: get_python_version()
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
Return the ``MAJOR.MINOR`` Python version number as a string. Similar to
|
2016-02-11 07:10:36 -04:00
|
|
|
``'%d.%d' % sys.version_info[:2]``.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
|
2010-02-02 19:17:47 -04:00
|
|
|
.. function:: get_platform()
|
|
|
|
|
|
|
|
Return a string that identifies the current platform.
|
|
|
|
|
|
|
|
This is used mainly to distinguish platform-specific build directories and
|
2010-02-11 16:47:18 -04:00
|
|
|
platform-specific built distributions. Typically includes the OS name and
|
2024-07-23 10:08:39 -03:00
|
|
|
version and the architecture (as supplied by :func:`os.uname`), although the
|
2017-09-04 20:36:05 -03:00
|
|
|
exact information included depends on the OS; e.g., on Linux, the kernel
|
|
|
|
version isn't particularly important.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
Examples of returned values:
|
|
|
|
|
|
|
|
- linux-i586
|
|
|
|
- linux-alpha (?)
|
|
|
|
- solaris-2.6-sun4u
|
|
|
|
|
|
|
|
Windows will return one of:
|
|
|
|
|
2018-12-05 15:45:30 -04:00
|
|
|
- win-amd64 (64bit Windows on AMD64, aka x86_64, Intel64, and EM64T)
|
2010-02-02 19:17:47 -04:00
|
|
|
- win32 (all others - specifically, sys.platform is returned)
|
|
|
|
|
2021-09-22 14:33:36 -03:00
|
|
|
macOS can return:
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
- macosx-10.6-ppc
|
|
|
|
- macosx-10.4-ppc64
|
|
|
|
- macosx-10.3-i386
|
|
|
|
- macosx-10.4-fat
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
For other non-POSIX platforms, currently just returns :data:`sys.platform`.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
.. function:: is_python_build()
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2016-08-25 11:13:24 -03:00
|
|
|
Return ``True`` if the running Python interpreter was built from source and
|
|
|
|
is being run from its built location, and not from a location resulting from
|
|
|
|
e.g. running ``make install`` or installing via a binary installer.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
.. function:: parse_config_h(fp[, vars])
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
Parse a :file:`config.h`\-style file.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
*fp* is a file-like object pointing to the :file:`config.h`\-like file.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
A dictionary containing name/value pairs is returned. If an optional
|
2010-02-11 16:47:18 -04:00
|
|
|
dictionary is passed in as the second argument, it is used instead of a new
|
|
|
|
dictionary, and updated with the values read in the file.
|
2010-02-02 19:17:47 -04:00
|
|
|
|
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
.. function:: get_config_h_filename()
|
2010-02-02 19:17:47 -04:00
|
|
|
|
2010-02-11 16:47:18 -04:00
|
|
|
Return the path of :file:`pyconfig.h`.
|
2010-05-25 06:44:36 -03:00
|
|
|
|
2010-09-20 12:29:53 -03:00
|
|
|
.. function:: get_makefile_filename()
|
|
|
|
|
|
|
|
Return the path of :file:`Makefile`.
|
|
|
|
|
2023-09-19 08:57:28 -03:00
|
|
|
.. _sysconfig-cli:
|
2021-04-23 09:02:41 -03:00
|
|
|
|
2010-05-25 06:44:36 -03:00
|
|
|
Using :mod:`sysconfig` as a script
|
|
|
|
----------------------------------
|
|
|
|
|
2016-07-26 06:18:21 -03:00
|
|
|
You can use :mod:`sysconfig` as a script with Python's *-m* option:
|
|
|
|
|
|
|
|
.. code-block:: shell-session
|
2010-05-25 06:44:36 -03:00
|
|
|
|
|
|
|
$ python -m sysconfig
|
|
|
|
Platform: "macosx-10.4-i386"
|
|
|
|
Python version: "3.2"
|
|
|
|
Current installation scheme: "posix_prefix"
|
|
|
|
|
|
|
|
Paths:
|
|
|
|
data = "/usr/local"
|
|
|
|
include = "/Users/tarek/Dev/svn.python.org/py3k/Include"
|
|
|
|
platinclude = "."
|
|
|
|
platlib = "/usr/local/lib/python3.2/site-packages"
|
|
|
|
platstdlib = "/usr/local/lib/python3.2"
|
|
|
|
purelib = "/usr/local/lib/python3.2/site-packages"
|
|
|
|
scripts = "/usr/local/bin"
|
|
|
|
stdlib = "/usr/local/lib/python3.2"
|
|
|
|
|
|
|
|
Variables:
|
|
|
|
AC_APPLE_UNIVERSAL_BUILD = "0"
|
|
|
|
AIX_GENUINE_CPLUSPLUS = "0"
|
|
|
|
AR = "ar"
|
|
|
|
ARFLAGS = "rc"
|
|
|
|
...
|
|
|
|
|
|
|
|
This call will print in the standard output the information returned by
|
|
|
|
:func:`get_platform`, :func:`get_python_version`, :func:`get_path` and
|
|
|
|
:func:`get_config_vars`.
|