Difference between revisions of "Set up a Python virtual environment"
(3 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
Python virtual environments run their own site directories, allowing them to be optionally | Python virtual environments run their own site directories, allowing them to be optionally isolated from system directories. This can easily avoid a potential nightmare of version conflicts - one piece of software on your system may require a certain version to run, while another make require a different one. | ||
== Create == | == Create == | ||
<code>venv</code> is | If you are using Python 3, you can use <code>venv</code>, which is part of its standard library. | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
Line 8: | Line 8: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
When this is run, <code>venv</code> creates the target directory (in this case <code>venv</code>), and any parent directories that don't exist yet. It also puts a <code>pyvenv.cfg</code> file with a <code>home</code> key that points to the installation of Python from where the command was run. | When this is run, <code>venv</code> creates the target directory (in this case, named <code>venv</code>), and any parent directories that don't exist yet. It also puts a <code>pyvenv.cfg</code> file with a <code>home</code> key that points to the installation of Python from where the command was run. | ||
== Activate == | == Activate == | ||
Line 15: | Line 15: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
You will see the prompt change to | You will see the prompt change to display <code>(venv)</code> at the beginning of the line: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
(venv)Username@Computer myfolder % | (venv) Username@Computer myfolder % | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Latest revision as of 20:56, 4 November 2021
Python virtual environments run their own site directories, allowing them to be optionally isolated from system directories. This can easily avoid a potential nightmare of version conflicts - one piece of software on your system may require a certain version to run, while another make require a different one.
Create
If you are using Python 3, you can use venv
, which is part of its standard library.
python3 -m venv venv
When this is run, venv
creates the target directory (in this case, named venv
), and any parent directories that don't exist yet. It also puts a pyvenv.cfg
file with a home
key that points to the installation of Python from where the command was run.
Activate
source venv/bin/activate
You will see the prompt change to display (venv)
at the beginning of the line:
(venv) Username@Computer myfolder %
Use
Install dependencies within the new Python virtual environment, using pip
, the default package manager for Unix-like systems such as Mac OS and Linux. Swap out the {packagename} for the package you want to install.
pip install {packagename}
Deactivate
To stop it, type:
deactivate
Close
Simply type
exit
Remove
To remove a Python virtual environment, first deactivate it. Then you can use rm
to remove it.
rm -r venv
A more thorough method is to specify removal of the files and folders made when the environment was created. In the folder where the venv is, run
rm -r bin include lib lib64 pyvenv.cfg share