Table of Contents
Python Project Workflow
For managing project dependencies, Node.js has
package.json files, PHP has
composer.json files. Fulfilling a similar need, Python has
pip and virtual environments, but they don't work quite like
Projects require virtual environments
The basic idea is that for each Python project, you define a virtual environment that harbors all the project's python dependencies.
The easiest way to go about things assuming your have
virtualenvwrapper installed on your system is as follows:
- Create a directory for your project:
$ mkdir ~/Dev/MyProject
- Create a virtual environment for your project:
$ mkvirtualenv MyProject
The actual virtual environment will be in
- Enable the virtual environment:
$ workon MyProject
- Install the packages you need:
$ pip install <whatever>
- When you are done, switch your shell back to “regular” mode:
- To see what environments are available:
without an argument.
- To set the Python version you want to use:
$ mkvirtualenv -p /usr/bin/python3 MyProject
Getting a list of packages in the virtual environment
When you want to deploy your project on another machine, you will want the environment on the host to use the same versions of the packages you used while developing it (i.e., those in your virtual environment). The process of generating a list of those packages and re-installing them is discussed in this this post from Miguel Grinberg's blog and in this Stack Overflow post.
Virtual environments and IDEs
Virtual environments present an added layer of complexity when using IDEs. To have the project run within the right environment and to get accurate auto completion and the like, the IDE needs somehow to be aware of the virtual environment it should use. Note that this might be a different environment than the one under which the IDE itself is preferred to run.
Each IDE is different, so generalized help is tricky. It might work to run the IDE from a shell that has its virtual environment set as desired, but this will run the IDE itself within that environment as well, which may not be what you want.