补充:在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.4。所有第三方的包都会被pip安装到Python3的site-packages目录下。

 

virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。

简单的创建,进入virtualenv和退出操作:

首先,用pip安装virtualenv:

$ pip3 install virtualenv

 

然后,假定我们要开发一个新的项目,需要一套独立的Python运行环境,可以这么做:

第一步,创建目录:

Mac:~ michael$ mkdir myproject 
Mac:~ michael$ cd myproject/ 
Mac:myproject michael$

 

第二步,创建一个独立的Python运行环境,命名为venv:

Mac:myproject michael$ virtualenv --no-site-packages venv 
Using base prefix '/usr/local/.../Python.framework/Versions/3.4' 
New python executable in venv/bin/python3.4 
Also creating executable in venv/bin/python 
Installing setuptools, pip, wheel...done.

命令virtualenv就可以创建一个独立的Python运行环境,我们还加上了参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。

新建的Python环境被放到当前目录下的venv目录。

 

第三步:有了venv这个Python环境,可以用source进入该环境:

Mac:myproject michael$ source venv/bin/activate 
(venv)Mac:myproject michael$

注意到命令提示符变了,有个(venv)前缀,表示当前环境是一个名为venv的Python环境。

下面正常安装各种第三方包,并运行python命令:

(venv)Mac:myproject michael$ pip install jinja2 
... 
Successfully installed jinja2-2.7.3 markupsafe-0.23 
(venv)Mac:myproject michael$ python myapp.py ...

在venv环境下,用pip安装的包都被安装到venv这个环境下,系统Python环境不受任何影响。也就是说,venv环境是专门针对myproject这个应用创建的。

 

第四步:退出当前的venv环境,使用deactivate命令:

(venv)Mac:myproject michael$ deactivate 
Mac:myproject michael$

此时就回到了正常的环境,现在pip或python均是在系统Python环境下执行。

 

virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令python和pip均指向当前的virtualenv环境。

 

小结

virtualenv为应用提供了隔离的Python运行环境,解决了不同应用间多版本的冲突问题。

 

问题:在env中是否能直接使用pip?需要单独安装不?

 

 

 

其他参考资料:

一、Installation

To install globally with pip (if you have pip 1.3 or greater installed globally):

$ [sudo] pip install virtualenv

Or to get the latest unreleased dev version:

$ [sudo] pip install https://github.com/pypa/virtualenv/tarball/develop

To install version X.X globally from source:

$ curl -O https://pypi.python.org/packages/source/v/virtualenv/virtualenv-X.X.tar.gz $ tar xvfz virtualenv-X.X.tar.gz $ cd virtualenv-X.X $ [sudo] python setup.py install

To use locally from source:

$ curl -O https://pypi.python.org/packages/source/v/virtualenv/virtualenv-X.X.tar.gz $ tar xvfz virtualenv-X.X.tar.gz $ cd virtualenv-X.X $ python virtualenv.py myVE

 

查看已经安装的版本

virtualenv --version

virtualenv python virtualenv python指向base_Python

 

二、User Guide

Virtualenv has one basic command:

$ virtualenv ENV

 

目录中自动创建了三个目录bin、include、lib

  • bin 包含了一些在这个虚拟环境中可用的命令,以及开启虚拟环境的脚步activate;
  • include 包含了虚拟环境中的头文件,以及Python的头文件
  • lib 包含了一些依赖库

 

On Posix systems, this resides in /ENV/bin/, so you can run:

$ source bin/activate

 

To undo these changes to your path (and prompt), just run:

$ deactivate

 

Removing an Environment

(ENV)$ deactivate$ rm -r /path/to/ENV

 

三、Refrence Guide

--version

-h, --help

-v, --verbose

Increase verbosity.

-q, --quiet

-p PYTHON_EXE, --python=PYTHON_EXE

The Python interpreter to use, e.g., –python=python2.5 will use the python2.5 interpreter to create the new environment. The default is the interpreter that virtualenv was installed with (like /usr/bin/python)

--clear

Clear out the non-root install and start from scratch.

--system-site-packages

Give the virtual environment access to the global site-packages.

--always-copy

Always copy files rather than symlinking.

--relocatable

Make an EXISTING virtualenv environment relocatable. This fixes up scripts and makes all .pth files relative.

--unzip-setuptools

Unzip Setuptools when installing it.

--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.

--extra-search-dir=DIR

Directory to look for setuptools/pip distributions in. This option can be specified multiple times.

--prompt=PROMPT

Provides an alternative prompt prefix for this environment.

--download

Download preinstalled packages from PyPI.

--no-download

Do not download preinstalled packages from PyPI.

--no-site-packages

DEPRECATED. Retained only for backward compatibility. Not having access to global site-packages is now the default behavior.

--distribute

--setuptools

希望志同道合的朋友可以提出建议,补充不足,多多交流,共同进步,不再迷茫!Just do it!