Working With Python's venv

Creating a venv

There are several ways to create a Python virtual environment, depending on the Python version you are running.

Before you read on, I want you to point you to another tool, called pipenv. It combines the functionality of tools that you are about to learn; virtualenv and pip. Futher on in this chapter, I will describe pipenv in detail.

Python 3.4 and above

If you are running Python 3.4+, you can use the venv module baked into Python:

$ python -m venv [directory]

This command will create a venv in the specified directory and copy pip and easy_install into it too.

All other versions

The alternative that works for any Python version is using the virtualenv package. You may need to install it first, system-wide, with:

$ sudo pip install virtualenv

Once installed, you can create a virtual environment with:

$ virtualenv [directory]

Activate the Virtual Environment

We activate our virtual environment with the source command. If you created your venv in the myvenv directory, the command would be:

$ source myvenv/bin/activate

That’s it! We’re ready to rock!

How It Works

When you activate a virtual environment, your $PATH variable is changed. You can see it for yourself, by printing the path with echo $PATH. In my case, it looks like this:


As you can see, the bin directory of your venv is put in front of everything else, overriding all the system-wide Python software.

If you take a look inside the directory of your venv (in this case: myvenv), you’ll see something like this:

Virtualenv directory tree
Virtualenv directory tree

You can see that:

  • The Python version is pinned to the version with which you created the venv, by creating a symlink to it.
  • All packages you install end up in the site-packages directory.

Deactivate a Virtual Environment

If you are done working on your project, it’s a good habit to deactivate its venv. Without deactivating it, all other Python code you execute will also run inside of it.

Deactivating your virtual environment couldn’t be simpler. Just enter this:

$ deactivate

If you liked this page, please share it with a fellow learner: