python 虚拟环境virtualenv virtualenvwrapper
文章目录
virtualenv
介绍
virtualenv 是一个创建隔绝的Python环境的工具。virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。
创建目录:
$ mkdir /web/soft/ python
$ cd /web/soft/ python
安装
$ pip3 install virtualenv
创建虚拟运行环境,命名为venv:
$ virtualenv --no-site-packages venv
命令virtualenv就可以创建一个独立的Python运行环境,我们还加上了参数–no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。
你可以选择使用一个Python解释器:
$ virtualenv -p /usr/bin/python2.7 venv # -p参数指定Python解释器程序路径
使用
新建的Python环境被放到当前目录下的venv目录。有了venv这个Python环境,可以用source进入该环境:
$ source venv/bin/activate
(venv) $
注意到命令提示符变了,有个(venv)前缀,表示当前环境是一个名为venv的Python环境。
下面正常安装各种第三方包,并运行python命令:
(venv)$ pip install jinja2
(venv)$ python myapp.py
在venv环境下,用pip安装的包都被安装到venv这个环境下,系统Python环境不受任何影响。也就是说,venv环境是专门针对myproject这个应用创建的。
退出
退出当前的venv环境,使用deactivate命令:
(venv)$ deactivate
$
此时就回到了正常的环境,现在pip或python均是在系统Python环境下执行。
virtualenvwrapper
提供了一系列命令使得和虚拟环境工作变得愉快许多。它把您所有的虚拟环境都放在一个地方。
将您的所有虚拟环境在一个地方。
包装用于管理虚拟环境(创建,删除,复制)。
使用一个命令来环境之间进行切换。
安装
安装(确保 virtualenv 已经安装了):
pip install virtualenvwrapper
export WORKON_HOME=~/Envs #设置环境变量
mkdir -p $WORKON_HOME #创建虚拟环境管理目录
find / -name virtualenvwrapper.sh #找到virtualenvwrapper.sh的路径
source 路径 #激活virtualenvwrapper.sh
默认virtualenvwrapper安装在下面python解释器中的site-packages,实际上需要运行virtualenvwrapper.sh文件才行;所以需要先进行配置一下:
找到virtualenvwrapper.sh的路径:
find / -name virtualenvwrapper.sh
运行virtualenvwrapper.sh文件:
source 路径
ps:每次要想使用virtualenvwrapper 工具时,都必须先激活virtualenvwrapper.sh,另外,如果创建前要将即将的环境保存到Envs中,就要先设置一下环境变量:export WORKON_HOME=~/Envs,再搭建
基本使用
创建一个虚拟环境:
$ mkvirtualenv project_env
这会在Envs 中创建 project_env虚拟环境
选择一个python解释器来搭建:
$ mkvirtualenv env -- python=python2.7
在虚拟环境上工作:
$ workon project_env
或者,您可以创建一个项目,它会创建虚拟环境,并在 $WORKON_HOME 中创建一个项目目录。 当您使用 workon project_env 时,会 cd -ed 到项目目录中。
$ mkvirtualenv project_env
virtualenvwrapper 提供环境名字的tab补全功能。当您有很多环境, 并且很难记住它们的名字时,这就显得很有用。
workon 也能停止您当前所在的环境,所以您可以在环境之间快速的切换。
停止虚拟环境
$ deactivate
删除:
$ rmvirtualenv project_env
其他有用的命令
lsvirtualenv #列举所有的环境。
cdvirtualenv #导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages。
cdsitepackages # 和上面的类似,但是是直接进入到 site-packages 目录中。
lssitepackages #显示 site-packages 目录中的内容。