virtualenv 安装使用

  • 不同的人喜欢用不同的方式建立各自的开发环境,但在几乎所有的编程社区,总有一个(或一个以上)开发环境让人更容易接受。 使用不同的开发环境虽然没有什么错误,但有些环境设置更容易进行便利的测试,并做一些重复/模板化的任务,使得在每天的日常工作简单并易于维护。

    什么是virtualenv?

    在Python的开发环境的最常用的方法是使用 virtualenv 包。 Virtualenv是一个用来创建独立的Python环境的包。现在,出现了这样的问题:为什么我们需要一个独立的Python环境? 要回答这个问题,请允许我引用virtualenv自己的文档:

    virtualenv is a tool to create isolated Python environments.

    The basic problem being addressed is one of dependencies and versions, and indirectly permissions. Imagine you have an application that needs version 1 of LibFoo, but another application requires version 2. How can you use both these applications? If you install everything into /usr/lib/python2.7/site-packages (or whatever your platform’s standard location is), it’s easy to end up in a situation where you unintentionally upgrade an application that shouldn’t be upgraded.

    Or more generally, what if you want to install an application and leave it be? If an application works, any change in its libraries or the versions of those libraries can break the application.

    Also, what if you can’t install packages into the global site-packages directory? For instance, on a shared host.

    In all these cases, virtualenv can help you. It creates an environment that has its own installation directories, that doesn’t share libraries with other virtualenv environments (and optionally doesn’t access the globally installed libraries either).

    我们需要处理的基本问题是包的依赖、版本和间接权限问题。想象一下,你有两个应用,一个应用需要libfoo的版本1,而另一应用需要版本2。如何才能同时使用这些应用程序?如果您安装到的/usr/lib/python2.7/site-packages(或任何平台的标准位置)的一切,在这种情况下,您可能会不小心升级不应该升级的应用程序。

    简单地说,你可以为每个项目建立不同的/独立的Python环境,你将为每个项目安装所有需要的软件包到它们各自独立的环境中。

    安装与使用virtualenv

    安装 virtualenv 很简单:

    pip install virtualenv
    

    virtualenv安装完毕后,可以通过运行下面的命令来为你的项目创建独立的python环境:

    mkdir nowamagic_venv
    virtualenv --distribute nowamagic_venv
    

    OK,成功。上面发生了什么?你创建了文件夹 nowamagic_venv 来存储你的新的独立Python环境。 这个文件夹位于 /root 下面。

    我们再来看看输出:

    New python executable in nowamagic_venv/bin/python2.7
    Also creating executable in nowamagic_venv/bin/python
    Installing Setuptools......done.
    Installing Pip...........done.
    

    --distribute 选项使virtualenv使用新的基于发行版的包管理系统而不是 setuptools 获得的包。 你现在需要知道的就是 --distribute 选项会自动在新的虚拟环境中安装 pip ,这样就不需要手动安装了。 当你成为一个更有经验的Python开发者,你就会明白其中细节。

    • activate:这个virtualenv的激活文件
    • pip:这个virtualenv的独立pip
    • python:python解释器的一个副本
    • lib/python2.7:所有的新包会被存在这

    试验一下

    通过下面的命令激活这个virtualenv:

    [[email protected] ~]# cd nowamagic_venv
    [[email protected] nowamagic_venv]# source bin/activate
    (nowamagic_venv)[[email protected] nowamagic_venv]#
    

    运行下面的命令可以更好地理解两者的差异,如果已经进入virtualenv请先离开。

    deactivate  #离开
    

    首先让我们看看如果调用python/pip命令它会调用那一个。

    [[email protected] ~]# which python
    /usr/bin/python
    
    [[email protected] ~]# which pip
    /usr/local/bin/pip
    

    再来一次!这次打开virtualenv,然后看看有什么不同。我的机子上显示如下:

    [[email protected] ~]# which python
    /root/nowamagic_venv/bin/python
    
    [[email protected] ~]# which pip
    /root/nowamagic_venv/bin/pip
    

    virtualenv拷贝了Python可执行文件的副本,并创建一些有用的脚本和安装了项目需要的软件包,你可以在项目的整个生命周期中安装/升级/删除这些包。 它也修改了一些搜索路径,例如PYTHONPATH,以确保:

    • 当安装包时,它们被安装在当前活动的virtualenv里,而不是系统范围内的Python路径。
    • 当import代码时,virtualenv将优先采取本环境中安装的包,而不是系统Python目录中安装的包。

    还有一点比较重要,在默认情况下,所有安装在系统范围内的包对于virtualenv是可见的。 这意味着如果你将simplejson安装在您的系统Python目录中,它会自动提供给所有的virtualenvs使用。 这种行为可以被更改,在创建virtualenv时增加 --no-site-packages 选项的virtualenv就不会读取系统包,如下:

    virtualenv nowamagic_venv --no-site-packages
    
    • 到这里,virtualenvs 就讲完了,很简单是不是?跟着步骤来,一切都是顺理成章的。而且也很强大,Python的开发环境配置起来变得非常简单。结合后面要讲的 virtualenvwrapper,可以自动管理多个环境,很神奇的。

    e>

时间: 2024-07-30 07:43:26

virtualenv 安装使用的相关文章

Python virtualenv安装库报错SSL: CERTIFICATE_VERIFY_FAILED

Python virtualenv安装库报错SSL: CERTIFICATE_VERIFY_FAILED 问题描写叙述 使用pip依照virtualenv报错,例如以下: pip install virtualenv Collecting virtualenv /opt/python27/lib/python2.7/site-packages/pip/_vendor/requests/packages/urllib3/util/ssl_.py:315: SNIMissingWarning: An

python虚拟环境virtualenv安装和配置

http://blog.csdn.net/pipisorry/article/details/47008981 python虚拟环境virtualenv VirtualEnv用于在一台机器上创建多个独立的python运行环境,VirtualEnvWrapper为前者提供了一些便利的命令行上的封装. Virtualenv是一个非常好的virtual python environment builder,他最大的好处是,可以让每一个python项目单独使用一个环境,而不会影响python系统环境,也

virtualenv安装

最近想学习flask,看到建议使用virtualenv,所以学习在linux平台安装 1.在root账户下执行 [[email protected]]# sudo easy_install virtualenv Searching for virtualenv Reading https://pypi.python.org/simple/virtualenv/ Best match: virtualenv 15.0.2 Downloading https://pypi.python.org/pa

python初探总结(pip、Django、mysqldb,mysql、sqlite3、apache, virtualenv安装配置)

安装配置: Python可应用于多平台包括 Linux 和 Mac OS X.一般的 Linux 发行版本都自带 Python,Mac OS X 最新版也自带了 Python,也就是已经安装好了,不需要再配置. linux和Mac环境下配置python: Python会安装在 /usr/lib/python** 目录中,Python库安装在/usr/local/lib/pythonXX,XX为你使用的Python的版本号. 找到记得这个位置可用于以后配置下python中的安装相应的lib库: M

python virtualenv安装说明

环境说明: virtualenv安装: 第一步,创建目录code: 第二步,创建一个独立的Python运行环境,命名为venv: 新建的Python环境被放到当前目录下的venv目录. 第三步,有了venv这个Python环境,可以用source激活该环境: 原文地址:https://www.cnblogs.com/apple2016/p/9265914.html

python virtualenv 安装运行saltstack

需求产生场景: 1.python的virtualenv虚拟环境非常的好用. 2.saltstack作为运维自动化的一个重要组件也挺好用的. 但是: 1.saltsatck最简便的是使用yum安装,结合的是linux-centos自带的python2.6版本. 2.即便使用编译安装,也是在编译安装的python环境下 so,需求产生了: 我想要在virtualenv环境下使用saltstack的api,发现非常蛋疼.两者无法整合到一起. 为了解决这个痛点,用了半个下午的时间,参考saltstack

tensorflow的Virtualenv安装方式安装

本文介绍了如何在ubuntu上以virtualenv方式安装tensorflow. 安装pip和virtualenv: # Ubuntu/Linux 64-bit sudo apt-get install python-pip python-dev python-virtualenv # Mac OS X sudo easy_install pip sudo pip install --upgrade virtualenv 创建 Virtualenv 虚拟环境: 进入你想安装tensorflow

点滴记录——CentOS 6.4中使用virtualenv安装swift

转载请说明出处:http://blog.csdn.net/cywosp/article/details/42150141 简述 在开发过程中,经常需要使用各种第三方库,而且python又提供了pip,easy_install等工具来简化库的安装,所以很容易就会在系统python的site-packages目录中装满各种各样的库,但是这样在下面几种情况下会有问题: 1.没有site-packages目录的写权限,比如共享主机 2.不同项目依赖同一个库的不同版本,而这两个版本又不向下兼容 3.在li

[Mac][Python][Virtualenv]安装配置和使用

安装帮助文档安装VirtualEnv报错如下 tekiMacBook-Air:workspaces hbai$ source /usr/local/bin/virtualenvwrapper.sh /usr/bin/python: No module named virtualenvwrapper virtualenvwrapper.sh: There was a problem running the initialization hooks. If Python could not impo