Environments and Package Managers¶
Pip and venv¶
Throughout this tutorial, we used pip
, a Python package manager, to install
our software and other Python software we needed. In Getting Started, we
used venv
to create a “virtual environment”, a sandbox separate from the
general system Python where we could install and use software without
interfering with any system Python tools or other projects.
This tool chain is perfectly valid and effective, but you made find that as your
project evolves, other tools might be necessary for managing packages and
virtual environments (e.g. if you need to work with multiple versions of
Python). There are many alternatives to venv
. This post of Stack Overflow is a good survey of the field.
Conda¶
Conda, which is both a package manager (like pip
) and an virtual
environment manager (like venv
) was developed specifically for the
scientific Python community. Conda is not limited to Python packages: it has
grown into a general-purpose user-space package manager. Many important
scientific Python packages have important dependencies that aren’t Python
packages and can’t be installed using pip
. Before conda, the user had to
sort out how to install these extra dependencies using the system package
manager, and it was a common pain point. Conda can install all of the
dependencies.
Conda is conceptually a heavier lift that pip
and venv
, which is why we
still with the basics in Getting Started, but it is extremely popular
among both beginners and experts, and we recommend becoming familiar with it.
Check whether conda
is already installed:
conda
If that is not found, follow the steps in the conda installation guide, which has instructions for Windows, OSX, and Linux. It offers both miniconda (a minimal installation) and Anaconda. For our purposes, either is suitable. Miniconda is a faster installation.
Now, create an environment.
conda create -n my-env python=3.6
The term my-env
can be anything. It names the new environment.
Every time you open up a new Terminal / Command Prompt to work on your
project, activate that environment. This means that when you type python3
or, equivalently, python
you will be getting a specific installation of
Python and Python packages, separate from any default installation on your
machine.
conda activate my-env
The use of virtual environments leads to multiple instances of python
,
pip
, ipython
, pytest
, flake8
and other executables on your
machine. If you encounter unexpected behavior, use which ____
to see which
environment a given command is coming from. (Linux and OSX only.)