| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | Creation of :ref:`virtual environments <venv-def>` is done by executing the | 
					
						
							|  |  |  | ``pyvenv`` script:: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pyvenv /path/to/new/virtual/environment | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Running this command creates the target directory (creating any parent | 
					
						
							|  |  |  | directories that don't exist already) and places a ``pyvenv.cfg`` file in it | 
					
						
							|  |  |  | with a ``home`` key pointing to the Python installation the command was run | 
					
						
							|  |  |  | from.  It also creates a ``bin`` (or ``Scripts`` on Windows) subdirectory | 
					
						
							|  |  |  | containing a copy of the ``python`` binary (or binaries, in the case of | 
					
						
							|  |  |  | Windows).  It also creates an (initially empty) ``lib/pythonX.Y/site-packages`` | 
					
						
							|  |  |  | subdirectory (on Windows, this is ``Lib\site-packages``). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 21:13:56 -07:00
										 |  |  | .. seealso:: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    `Python Packaging User Guide: Creating and using virtual environments | 
					
						
							| 
									
										
										
										
											2016-01-30 12:24:31 +02:00
										 |  |  |    <https://packaging.python.org/en/latest/installing/#creating-virtual-environments>`__
 | 
					
						
							| 
									
										
										
										
											2014-03-15 21:13:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | .. highlight:: none | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | On Windows, you may have to invoke the ``pyvenv`` script as follows, if you | 
					
						
							|  |  |  | don't have the relevant PATH and PATHEXT settings:: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 10:57:36 +00:00
										 |  |  |     c:\Temp>c:\Python35\python c:\Python35\Tools\Scripts\pyvenv.py myenv | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | or equivalently:: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 10:57:36 +00:00
										 |  |  |     c:\Temp>c:\Python35\python -m venv myenv | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The command, if run with ``-h``, will show the available options:: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-30 12:17:10 +02:00
										 |  |  |     usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear] | 
					
						
							|  |  |  |                 [--upgrade] [--without-pip] | 
					
						
							|  |  |  |                 ENV_DIR [ENV_DIR ...] | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     Creates virtual Python environments in one or more target directories. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     positional arguments: | 
					
						
							|  |  |  |       ENV_DIR             A directory to create the environment in. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     optional arguments: | 
					
						
							|  |  |  |       -h, --help             show this help message and exit | 
					
						
							| 
									
										
										
										
											2016-01-30 12:17:10 +02:00
										 |  |  |       --system-site-packages Give the virtual environment access to the system | 
					
						
							|  |  |  |                              site-packages dir. | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  |       --symlinks             Try to use symlinks rather than copies, when symlinks | 
					
						
							|  |  |  |                              are not the default for the platform. | 
					
						
							| 
									
										
										
										
											2014-03-15 21:13:56 -07:00
										 |  |  |       --copies               Try to use copies rather than symlinks, even when | 
					
						
							|  |  |  |                              symlinks are the default for the platform. | 
					
						
							| 
									
										
										
										
											2016-01-28 09:01:26 +02:00
										 |  |  |       --clear                Delete the contents of the environment directory if it | 
					
						
							|  |  |  |                              already exists, before environment creation. | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  |       --upgrade              Upgrade the environment directory to use this version | 
					
						
							|  |  |  |                              of Python, assuming Python has been upgraded in-place. | 
					
						
							| 
									
										
										
										
											2013-11-23 00:30:34 +10:00
										 |  |  |       --without-pip          Skips installing or upgrading pip in the virtual | 
					
						
							|  |  |  |                              environment (pip is bootstrapped by default) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 10:52:02 +00:00
										 |  |  | Depending on how the ``venv`` functionality has been invoked, the usage message | 
					
						
							|  |  |  | may vary slightly, e.g. referencing ``pyvenv`` rather than ``venv``. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-23 00:30:34 +10:00
										 |  |  | .. versionchanged:: 3.4 | 
					
						
							| 
									
										
										
										
											2014-03-15 21:13:56 -07:00
										 |  |  |    Installs pip by default, added the ``--without-pip``  and ``--copies`` | 
					
						
							|  |  |  |    options | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-23 19:35:12 +00:00
										 |  |  | .. versionchanged:: 3.4 | 
					
						
							|  |  |  |    In earlier versions, if the target directory already existed, an error was | 
					
						
							|  |  |  |    raised, unless the ``--clear`` or ``--upgrade`` option was provided. Now, | 
					
						
							|  |  |  |    if an existing directory is specified, its contents are removed and | 
					
						
							|  |  |  |    the directory is processed as if it had been newly created. | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The created ``pyvenv.cfg`` file also includes the | 
					
						
							|  |  |  | ``include-system-site-packages`` key, set to ``true`` if ``venv`` is | 
					
						
							|  |  |  | run with the ``--system-site-packages`` option, ``false`` otherwise. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-23 00:30:34 +10:00
										 |  |  | Unless the ``--without-pip`` option is given, :mod:`ensurepip` will be | 
					
						
							|  |  |  | invoked to bootstrap ``pip`` into the virtual environment. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | Multiple paths can be given to ``pyvenv``, in which case an identical | 
					
						
							|  |  |  | virtualenv will be created, according to the given options, at each | 
					
						
							|  |  |  | provided path. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Once a venv has been created, it can be "activated" using a script in the | 
					
						
							| 
									
										
										
										
											2012-10-04 21:48:58 +03:00
										 |  |  | venv's binary directory. The invocation of the script is platform-specific: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							|  |  |  | | Platform    | Shell           | Command to activate virtual environment | | 
					
						
							|  |  |  | +=============+=================+=========================================+ | 
					
						
							|  |  |  | | Posix       | bash/zsh        | $ source <venv>/bin/activate            | | 
					
						
							|  |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							|  |  |  | |             | fish            | $ . <venv>/bin/activate.fish            | | 
					
						
							|  |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							|  |  |  | |             | csh/tcsh        | $ source <venv>/bin/activate.csh        | | 
					
						
							|  |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							| 
									
										
										
										
											2016-06-27 09:51:40 +03:00
										 |  |  | | Windows     | cmd.exe         | C:\> <venv>\\Scripts\\activate.bat      | | 
					
						
							| 
									
										
										
										
											2012-10-04 21:48:58 +03:00
										 |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							| 
									
										
										
										
											2016-06-27 09:51:40 +03:00
										 |  |  | |             | PowerShell      | PS C:\> <venv>\\Scripts\\Activate.ps1   | | 
					
						
							| 
									
										
										
										
											2012-10-04 21:48:58 +03:00
										 |  |  | +-------------+-----------------+-----------------------------------------+ | 
					
						
							| 
									
										
										
										
											2012-07-10 08:21:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | You don't specifically *need* to activate an environment; activation just | 
					
						
							|  |  |  | prepends the venv's binary directory to your path, so that "python" invokes the | 
					
						
							|  |  |  | venv's Python interpreter and you can run installed scripts without having to | 
					
						
							|  |  |  | use their full path. However, all scripts installed in a venv should be | 
					
						
							|  |  |  | runnable without activating it, and run with the venv's Python automatically. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You can deactivate a venv by typing "deactivate" in your shell. The exact | 
					
						
							|  |  |  | mechanism is platform-specific: for example, the Bash activation script defines | 
					
						
							|  |  |  | a "deactivate" function, whereas on Windows there are separate scripts called | 
					
						
							|  |  |  | ``deactivate.bat`` and ``Deactivate.ps1`` which are installed when the venv is | 
					
						
							|  |  |  | created. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-25 23:21:03 -05:00
										 |  |  | .. versionadded:: 3.4 | 
					
						
							|  |  |  |    ``fish`` and ``csh`` activation scripts. |