1. virtualenv

Python2 和 Python3 均支持的方式

1.1 安装

pip install virtualenv

1.2 创建项目

cd my_project_folder
virtualenv my_project

1.3 指定 python 版本

virtualenv -p /usr/bin/python2.7 my_project

或者在环境变量配置中加入

export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python2.7

1.4 激活虚拟环境

(Linux) source my_project/bin/activate
(Windows) my_project\Scripts\activate

1.5 退出环境

(Linux) my_project/bin/deactivate
(Windows) my_project\Scripts\deactivate.bat

1.6 virtualenv 常用命令选项

virtualenv [OPTIONS] DEST_DIR

Options:
–version     显示版本信息。
-h, –help     显示帮助信息。
-v, –verbose   增加后台输出的信息。
-q, –quiet    控制后台输出的信息。
-p PYTHON_EXE, –python=PYTHON_EXE  
         指定 Python 解释器
–clear      清除虚拟环境中依赖库,初始化环境。
–system-site-packages
         使用当前 Python 主体上已安装的程序库。
–always-copy   一概不使用 符号链接,直接复制文件。
–no-setuptools  Do not install setuptools in the new virtualenv.
–no-pip     Do not install pip in the new virtualenv.
–no-wheel    Do not install wheel in the new virtualenv.

1.7 virtualenv 相关扩展

virtualenvwrapper

virtualenv 的扩展包,能方便的管理 virtualenv

1.7.1 安装

环境变量 WORKON_HOME 指定虚拟环境位置

(Linux)
pip install virtualenvwrapper
export WORKON_HOME=~/Envs
source /usr/local/bin/virtualenvwrapper.sh
(Windows)
pip install virtualenvwrapper-win
WORKON_HOME 默认值是 %USERPROFILE%Envs

1.7.2 基本用法

创建虚拟环境

mkvirtualenv myenv

切换到虚拟环境

workon myenv

虚拟环境和项目分开

mkproject my_project
虚拟环境在 WORKON_HOME 中,项目在 PROJECT_HOME 中

退出虚拟环境

deactivate

删除虚拟环境

rmvirtualenv myenv

其它用法

lsvirtualenv 列举所有的环境。
cdvirtualenv [subdir] 导航到当前激活的虚拟环境的目录中
cdsitepackages [subdir] 和上面的类似,但是是直接进入到 site-packages 目录中
lssitepackages 显示 site-packages 目录中的内容
showvirtualenv [env] 显示指定环境的详情
cpvirtualenv [source] [dest] 复制一份虚拟环境
allvirtualenv 对当前虚拟环境执行统一的命令
add2virtualenv [dir] [dir] 把指定的目录加入当前使用的环境的path中,这常使用
于在多个project里面同时使用一个较大的库的情况
toggleglobalsitepackages -q 控制当前的环境是否使用全局的sitepackages目录

virtualenv-burrito
相当于 virtualenv + virtualenvwrapper ,不过只支持 python 2

autoenv
当进入到一个包含 .env 的目录,autoenv 会自动激活该环境
pip install autoenv

2. venv

Python3 支持的方式,原名又 pyvenv,python 3.6 已弃用

2.1 创建虚拟环境

python3 -m venv /path/to/new/virtual/environment

2.2 命令帮助

python3 -m venv -h

usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear]
            [--upgrade] [--without-pip] [--prompt PROMPT]
            ENV_DIR [ENV_DIR ...]
Creates virtual Python environments in one or more target directories.
positional arguments:
  ENV_DIR              A directory to create the environment in.
optional arguments:
  -h, --help              帮助信息
  --system-site-packages  给虚拟环境访问系统 site-packages 目录的权限
  --symlinks              当系统默认不是符号链接的方式时,尝试使用符号链接而不是复制。
  --copies                尝试使用复制而不是符号链接,即使符号链接是平台默认的方式。
  --clear                 在虚拟环境创建之前,删除已存在的虚拟环境目录。
  --upgrade               使用当前 python,升级虚拟环境目录。
  --without-pip           跳过pip的升级或安装
  --prompt PROMPT         为该环境提供一个提示前缀

Once an environment has been created, you may wish to activate it, e.g. by
sourcing an activate script in its bin directory.

2.3 不同平台激活虚拟环境方法

激活方法

Platform

Shell

激活虚拟环境命令

Posix

bash/zsh

$ source /bin/activate

fish

$ . /bin/activate.fish

csh/tcsh

$ source /bin/activate.csh

Windows

cmd.exe

C:> \Scripts\activate.bat

PowerShell

C:> \Scripts\Activate.ps1