An ultimate guide on effectively managing Python virtual environments using different tools in Python ecosystem.
Popular Python virtual environment management options:
- [1] venv
- [2] virtualenv
- [3] virtualenvwrapper
- [4] pipenv
- [5] poetry
- [6] pyenv-virtualenv
- [7] conda
- [8] mamba
- [9] pixi
- [10] hatch
- [11] pdm
- [12] pew
- [13] tox
- [14] nox
- [15] rye
- [16] uv
It's glad that the Python ecosystem offers numerous options for managing virtual environments and dependencies. Yet, for beginners, this abundance may lead to the common question: Which one should I choose? In this section, I aim to share my experience and opinions to guide beginners to make right choices.
None could be more easy than venv
, as it is a Python (>=3.3) built-in module, nonthing needs to be installed, just running command python -m venv
to use it.
If you simply want to create a virtual environment for your Python project, and don't want to install third party packages for this purpose, then go for with venv
.
As a beginner, you could start with venv
and pip
, where use venv
to create virtual environment, and use pip
to manage environment dependencies.
Please notice that venv
does not support older versions of Python (<3.3 or 2.x), you will need to a third-party tool to help in this case.
virtualenv
instead is an independent library to create isolated Python environments, and a subset of virtualenv
has been integrated into the standard library under
the venv
module. If you try to use a third-party library to manage Pyton virtual environments, then I highly recommend learning and trying with it.
Compared to venv
, here are some advantages of virtualenv
:
- it is faster
- it is extendable
- it can create environments for any python versions.
- it is upgrade-able via
pip
. - it has rich programmatic API.
Besides, several other popular tools like virtualenvwrapper
, pew
, tox
and nox
are depending on virtualenv
and build abstractions on top of it.
virtualenv
wrappers provide convenient commands to help create and delete virtual environments, otherwise managing the development workflow and making it easier
to work on multiple projects without dependency conflicts.
virtualenvwrapper
and pew
are popular wrappers built on top of virtualenv
, and both of the are great choices. The workon
command is really convenient to help
switch environments when working on multiple Python projects with different dependencies.
For virtualenvwrapper
:
virtualenvwrapper
automated tests run under these shells on OS X and Linux with bash and zsh.- Windows users need to usea separately distributed re-implementation with
virtualenvwrapper-win
. virtualenvwrapper
is a set of shell functions defined in Bourne shell compatible syntax.
For pew
:
- It would luanch a subshell when activating the environment.
- It is completely shell-agnostic and thus works on bash, zsh, fish, powershell, etc.
- It is invoked starting with
pew
in commands.
As a zsh user under both Ubuntu and MacOS, I personally like the command style and syntax of virtualenvwrapper
, like mkvirtualenv
, rmvirtualenv
.
And I have been using it for years, there is no reason for me to switch from virtualenvwrapper
to pew
yet.
But again, both of them are great, the choice depends on your work environment and personal flavor.
tox
is a popular tool in the Python ecosystem used for testing and building projects across different environments.
It is particularly useful for ensuring that your Python project works consistently across various Python versions and environments.
It uses a declarative configuration file, typically named tox.ini
, where you specify the testing environments, dependencies, and commands.
nox
is another testing and automation tool for Python projects. Unlike tox
, nox
uses a code-based configuration approach, named noxfile.py
tox
and nox
serve similar purposes but differ in their configuration styles and approaches.
The choice between them depends on the preferences and requirements of the project and its developers.
Typically, you lack significant control over the versions of your system Python, the Python version pre-installed with operating systems such as Linux and MacOS. These pre-installed Python versions often lag behind the latest releases. Installing and effortlessly switching between multiple Python versions on your machine can be challenging.
pyenv
is designed to manage multiple versions of Python on your machine. It's not specifically designed for creating virtual environments,
but it allows you to switch between different versions of Python on same machine easily. pyenv-virtualenv
is an extension for pyenv
that
adds support for managing virtual environments, allowing you to create and switch between virtual environments associated with specific Python versions.
With venv
and virtualenv
, you can create virtual environments, but need pip
to help manage the dependencies.
pipenv
, poetry
hatch
, pdm
, these tools not only provides the support of Python environment creation, but also contains functionalities that help
manage Python dependencies.
hatch
,poetry
, andpdm
utilize thepyproject.toml
file to manage dependencies, wherepyproject.toml
is is the specified file format of PEP 518 which contains the build system requirements of Python projects.pipenv
usePipfile
andPipefile.lock
to manage the depdendencies. At the time of writing, there is an issue open for discussingPipfile
andpyproject.toml
- pypa/pipenv#5673
conda
works consistently across various operating systems, including Linux, macOS, and Windows.
This agnostic nature makes it a versatile tool for managing environments and packages in a way
that is independent of the underlying operating system.
conda
is a popular choice for data science and various other fields. For example,
GDAL (Geospatial Data Abstraction Library), which is crucial for tasks like spatial data processing and analysis.
Installing and managing these dependencies directly on a machine can be a complex and challenging process,
particularly when aiming to manage different versions for optimal functionality.
This is where conda
shines as an indispensable tool for geospatial data science.
However, conda
environment is relatively heavy, and the size of the environment would be larger than environments created by using other tools. Also, it's common that installing packages via conda
is slow.
mamba
is a reimplementation and drop-in replacement for conda
, designed in C++
to provide improved performance and efficiency. One of the key advantages of mamba
is its speed; it is generally faster and more efficient at resolving dependencies compared to conda
. This can significantly reduce the time required for package installation and environment management. The commands and usage of mamba
are almost identical to those of conda
, making it easy for users to switch without having to learn new syntax or commands.
pixi
, written in Rust, is a modern, cross-platform, multi-language package manager and workflow tool built on the fundation of the conda
ecosystem. This is especially useful when you are working with multiple Python interpreters and bindings to C and C++ libraries. For example, GDAL from PyPI
does not have binary C dependencies, but the conda
package does. On the other hand, some packages are only available through PyPI
, which pixi
can also install for you, best of both world. Besides, it introduces a project-centric approach rather than focusing on solely on environments, like what conda
and mamba
do. This shift towards projects offers a more organized and efficient way to manage dependencies and run code, tailored to modern development practices.
rye
originated as a personal project by Armin, driven by his desire to establish a one-stop-shop solution for all Python-related requirements.
rye
is an experimental endeavour to build a new type of packaging experience to Python inspired by rustup
and cargo
from Rust.
While I haven't personally incorporated it into my projects, rye has gained popularity on GitHub. If you're open to exploring innovative tools,
consider giving it a try.
uv
takes stewardship of rye
, and will be expanded into a unified successor project, to fulfill the shared vision for Python packaging with rye
.
uv
is an extremely fast Python package resolver and installer, written in Rust. uv
is designed as a drop-in replacement for pip
and pip-tools
,
and is ready for production use today in projects built around those workflows. I've applied uv
in my projects,
and it performs remarkably fast, living up to its advertised speed.
There isn't a one-size-fits-all solution for managing environments and dependencies in Python projects, as each has its own strengths and weaknesses. It's essential to try with various tools to discover the one that best suits your needs and aligns with your project's requirements.
If you have any question about this opinionated list, do not hesitate to contact me @jgujerry on X (Twitter) or open an issue on GitHub.
This project is released under MIT License