blob: ddb36f94667d9f5e5d83b302217b91acf33c16b1 [file] [log] [blame]
Vinay Sajipc4618e32012-07-10 08:21:07 +01001Creation of :ref:`virtual environments <venv-def>` is done by executing the
Brett Cannon15552c32016-07-08 10:46:21 -07002command ``venv``::
Vinay Sajipc4618e32012-07-10 08:21:07 +01003
Brett Cannon15552c32016-07-08 10:46:21 -07004 python3 -m venv /path/to/new/virtual/environment
Vinay Sajipc4618e32012-07-10 08:21:07 +01005
6Running this command creates the target directory (creating any parent
7directories that don't exist already) and places a ``pyvenv.cfg`` file in it
Brett Cannon15552c32016-07-08 10:46:21 -07008with a ``home`` key pointing to the Python installation from which the command
Brett Cannonf9f8e3c2019-06-28 12:14:31 -07009was run (a common name for the target directory is ``.venv``). It also creates
10a ``bin`` (or ``Scripts`` on Windows) subdirectory containing a copy/symlink
11of the Python binary/binaries (as appropriate for the platform or arguments
12used at environment creation time). It also creates an (initially empty)
13``lib/pythonX.Y/site-packages`` subdirectory (on Windows, this is
14``Lib\site-packages``). If an existing directory is specified, it will be
15re-used.
Vinay Sajipc4618e32012-07-10 08:21:07 +010016
Brett Cannon15552c32016-07-08 10:46:21 -070017.. deprecated:: 3.6
18 ``pyvenv`` was the recommended tool for creating virtual environments for
19 Python 3.3 and 3.4, and is `deprecated in Python 3.6
20 <https://docs.python.org/dev/whatsnew/3.6.html#deprecated-features>`_.
21
22.. versionchanged:: 3.5
23 The use of ``venv`` is now recommended for creating virtual environments.
24
Vinay Sajipc4618e32012-07-10 08:21:07 +010025.. highlight:: none
26
Brett Cannon15552c32016-07-08 10:46:21 -070027On Windows, invoke the ``venv`` command as follows::
Vinay Sajipc4618e32012-07-10 08:21:07 +010028
Brett Cannon15552c32016-07-08 10:46:21 -070029 c:\>c:\Python35\python -m venv c:\path\to\myenv
Vinay Sajipc4618e32012-07-10 08:21:07 +010030
Brett Cannon15552c32016-07-08 10:46:21 -070031Alternatively, if you configured the ``PATH`` and ``PATHEXT`` variables for
32your :ref:`Python installation <using-on-windows>`::
Vinay Sajipc4618e32012-07-10 08:21:07 +010033
cocoatomod609b0c2017-10-27 13:42:11 +090034 c:\>python -m venv c:\path\to\myenv
Vinay Sajipc4618e32012-07-10 08:21:07 +010035
36The command, if run with ``-h``, will show the available options::
37
Berker Peksaga9744ae2016-01-30 12:17:10 +020038 usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear]
Cooper Lees4acdbf12019-06-17 11:18:14 -070039 [--upgrade] [--without-pip] [--prompt PROMPT] [--upgrade-deps]
Berker Peksaga9744ae2016-01-30 12:17:10 +020040 ENV_DIR [ENV_DIR ...]
Vinay Sajipc4618e32012-07-10 08:21:07 +010041
42 Creates virtual Python environments in one or more target directories.
43
44 positional arguments:
Brett Cannon15552c32016-07-08 10:46:21 -070045 ENV_DIR A directory to create the environment in.
Vinay Sajipc4618e32012-07-10 08:21:07 +010046
47 optional arguments:
Brett Cannon15552c32016-07-08 10:46:21 -070048 -h, --help show this help message and exit
49 --system-site-packages
50 Give the virtual environment access to the system
51 site-packages dir.
52 --symlinks Try to use symlinks rather than copies, when symlinks
53 are not the default for the platform.
54 --copies Try to use copies rather than symlinks, even when
55 symlinks are the default for the platform.
56 --clear Delete the contents of the environment directory if it
57 already exists, before environment creation.
58 --upgrade Upgrade the environment directory to use this version
59 of Python, assuming Python has been upgraded in-place.
60 --without-pip Skips installing or upgrading pip in the virtual
61 environment (pip is bootstrapped by default)
Holger Frey32088802019-02-22 12:05:20 +010062 --prompt PROMPT Provides an alternative prompt prefix for this
63 environment.
Cooper Lees4acdbf12019-06-17 11:18:14 -070064 --upgrade-deps Upgrade core dependencies: pip setuptools to the
65 latest version in PyPI
Nick Coghlan8fbdb092013-11-23 00:30:34 +100066
Brett Cannon15552c32016-07-08 10:46:21 -070067 Once an environment has been created, you may wish to activate it, e.g. by
68 sourcing an activate script in its bin directory.
Vinay Sajipc7e34fb2015-02-07 10:52:02 +000069
johnthagen1264d042020-09-05 16:53:47 -040070.. versionchanged:: 3.9
Cooper Lees4acdbf12019-06-17 11:18:14 -070071 Add ``--upgrade-deps`` option to upgrade pip + setuptools to the latest on PyPI
72
Nick Coghlan8fbdb092013-11-23 00:30:34 +100073.. versionchanged:: 3.4
Larry Hastings3732ed22014-03-15 21:13:56 -070074 Installs pip by default, added the ``--without-pip`` and ``--copies``
75 options
Vinay Sajipc4618e32012-07-10 08:21:07 +010076
Vinay Sajip71e72962015-01-23 19:35:12 +000077.. versionchanged:: 3.4
78 In earlier versions, if the target directory already existed, an error was
TROUVERIE Joachime8eb9722018-02-18 17:52:36 +010079 raised, unless the ``--clear`` or ``--upgrade`` option was provided.
Vinay Sajipc4618e32012-07-10 08:21:07 +010080
Steve Dowera1f9a332019-01-30 13:49:14 -080081.. note::
82 While symlinks are supported on Windows, they are not recommended. Of
83 particular note is that double-clicking ``python.exe`` in File Explorer
84 will resolve the symlink eagerly and ignore the virtual environment.
85
Derek Keeler45217af2020-04-02 12:00:21 -070086.. note::
87 On Microsoft Windows, it may be required to enable the ``Activate.ps1``
88 script by setting the execution policy for the user. You can do this by
89 issuing the following PowerShell command:
90
91 PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
92
93 See `About Execution Policies
Miro HronĨokef169582020-05-25 16:54:14 +020094 <https://go.microsoft.com/fwlink/?LinkID=135170>`_
Derek Keeler45217af2020-04-02 12:00:21 -070095 for more information.
96
Vinay Sajipc4618e32012-07-10 08:21:07 +010097The created ``pyvenv.cfg`` file also includes the
98``include-system-site-packages`` key, set to ``true`` if ``venv`` is
99run with the ``--system-site-packages`` option, ``false`` otherwise.
100
Nick Coghlan8fbdb092013-11-23 00:30:34 +1000101Unless the ``--without-pip`` option is given, :mod:`ensurepip` will be
102invoked to bootstrap ``pip`` into the virtual environment.
103
Brett Cannon15552c32016-07-08 10:46:21 -0700104Multiple paths can be given to ``venv``, in which case an identical virtual
105environment will be created, according to the given options, at each provided
106path.
Vinay Sajipc4618e32012-07-10 08:21:07 +0100107
Brett Cannon15552c32016-07-08 10:46:21 -0700108Once a virtual environment has been created, it can be "activated" using a
109script in the virtual environment's binary directory. The invocation of the
Julien Palardd936a8f2018-11-21 09:40:05 +0100110script is platform-specific (`<venv>` must be replaced by the path of the
111directory containing the virtual environment):
Vinay Sajipc4618e32012-07-10 08:21:07 +0100112
Andrew Svetlov65e9c572012-10-04 21:48:58 +0300113+-------------+-----------------+-----------------------------------------+
114| Platform | Shell | Command to activate virtual environment |
115+=============+=================+=========================================+
Brett Cannonf9f8e3c2019-06-28 12:14:31 -0700116| POSIX | bash/zsh | $ source <venv>/bin/activate |
Andrew Svetlov65e9c572012-10-04 21:48:58 +0300117+-------------+-----------------+-----------------------------------------+
Brett Cannon84b1ff62019-11-22 23:32:27 -0800118| | fish | $ source <venv>/bin/activate.fish |
Andrew Svetlov65e9c572012-10-04 21:48:58 +0300119+-------------+-----------------+-----------------------------------------+
120| | csh/tcsh | $ source <venv>/bin/activate.csh |
121+-------------+-----------------+-----------------------------------------+
Brett Cannonf9f8e3c2019-06-28 12:14:31 -0700122| | PowerShell Core | $ <venv>/bin/Activate.ps1 |
123+-------------+-----------------+-----------------------------------------+
Berker Peksag6803f352016-06-27 13:10:47 +0300124| Windows | cmd.exe | C:\\> <venv>\\Scripts\\activate.bat |
Andrew Svetlov65e9c572012-10-04 21:48:58 +0300125+-------------+-----------------+-----------------------------------------+
Berker Peksag6803f352016-06-27 13:10:47 +0300126| | PowerShell | PS C:\\> <venv>\\Scripts\\Activate.ps1 |
Andrew Svetlov65e9c572012-10-04 21:48:58 +0300127+-------------+-----------------+-----------------------------------------+
Vinay Sajipc4618e32012-07-10 08:21:07 +0100128
Andre Delfino3584d4b2020-09-01 03:07:29 -0300129When a virtual environment is active, the :envvar:`VIRTUAL_ENV` environment
130variable is set to the path of the virtual environment. This can be used to
131check if one is running inside a virtual environment.
132
Vinay Sajipc4618e32012-07-10 08:21:07 +0100133You don't specifically *need* to activate an environment; activation just
Brett Cannon15552c32016-07-08 10:46:21 -0700134prepends the virtual environment's binary directory to your path, so that
135"python" invokes the virtual environment's Python interpreter and you can run
136installed scripts without having to use their full path. However, all scripts
137installed in a virtual environment should be runnable without activating it,
138and run with the virtual environment's Python automatically.
Vinay Sajipc4618e32012-07-10 08:21:07 +0100139
Brett Cannon15552c32016-07-08 10:46:21 -0700140You can deactivate a virtual environment by typing "deactivate" in your shell.
Derek Keeler91e49572019-07-26 14:57:11 -0700141The exact mechanism is platform-specific and is an internal implementation
142detail (typically a script or shell function will be used).
Vinay Sajipc4618e32012-07-10 08:21:07 +0100143
R David Murray575fb312013-12-25 23:21:03 -0500144.. versionadded:: 3.4
145 ``fish`` and ``csh`` activation scripts.
Brett Cannonf9f8e3c2019-06-28 12:14:31 -0700146
147.. versionadded:: 3.8
148 PowerShell activation scripts installed under POSIX for PowerShell Core
149 support.