python开发之virtualenv与virtualenvwrapper讲解
在使用 Python
开发的过程中,工程一多,难免会碰到不同的工程依赖不同版本的库的问题;
亦或者是在开发过程中不想让物理环境里充斥各种各样的库,引发未来的依赖灾难。
此时,我们需要对于不同的工程使用不同的虚拟环境来保持开发环境以及宿主环境的清洁。
这里,就要隆重介绍 virtualenv
,一个可以帮助我们管理不同 Python
环境的绝好工具。
virtualenv
可以在系统中建立多个不同并且相互不干扰的虚拟环境。
一、Linux下安装、配置virtualenv
#指定清华源下载pip的包pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv#升级pip工具pip3 install --upgrade pip
1.安装virtualenvpip3 install virtualenv 2.创建目录mkdir Myprojectcd Myproject3.创建独立运行环境-命名virtualenv --no-site-packages --python=python3 venv#得到独立第三方包的环境,并且指定解释器是python34.进入虚拟环境source venv/bin/activate#此时进入虚拟环境(venv)Myproject5.安装第三方包(venv)Myproject: pip3 install django==1.9.8#此时pip的包都会安装到venv环境下,venv是针对Myproject创建的6.退出venv环境deactivate命令7.virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令python和pip均指向当前的virtualenv环境。
二、确保开发环境的一致性
1.假设我们在本地开发环境,准备好了项目+依赖包环境2.现在需要将项目上传至服务器,上线发布3.那么就要保证服务器的python环境一致性
pip3 freeze > requirements.txt 这将会创建一个 requirements.txt 文件,其中包含了当前环境中所有包及 各自的版本的简单列表。可以使用 “pip list”在不产生requirements文件的情况下, 查看已安装包的列表。pip3 install -r requirements.txt
三、虚拟环境之virtualenvwrapper
virtualenv
的一个最大的缺点就是:
每次开启虚拟环境之前要去虚拟环境所在目录下的 bin
目录下 source
一下 activate
,这就需要我们记住每个虚拟环境所在的目录。
并且还有可能你忘记了虚拟环境放在哪。。。
一种可行的解决方案是,将所有的虚拟环境目录全都集中起来,例如/opt/all_venv/,并且针对不同的目录做不同的事。
使用virtualenvwrapper管理你的虚拟环境(virtualenv),其实他就是统一管理虚拟环境的目录,并且省去了source的步骤。
步骤1:安装virtualenvwrapper
pip3 install virtualenvwrapper
步骤2:设置Linux的用户个人配置文件
把下面两行代码添加到 ~/.bashrc文件中打开文件vim ~/.bashrc写入以下几行代码(export可以先去掉)export WORKON_HOME=~/Envs # 设置virtualenv的统一管理目录, 以后自动下载的虚拟环境,全部都放在这export VIRTUALENVWRAPPER_VIRTUALENV_ARGS='--no-site-packages' # 添加virtualenvwrapper的参数,生成干净隔绝的环境export VIRTUALENVWRAPPER_PYTHON=/opt/python347/bin/python3 # 指定python解释器的本体(注意此路径随不同的linux环境改变而改变)source /opt/python34/bin/virtualenvwrapper.sh # 执行virtualenvwrapper安装脚本读取文件,使得生效,此时已经可以使用virtalenvwrappersource ~/.bashrc退出会话,重新登录生效,且每次登录的时候,就自动加载virtualenvwrapper工具
步骤3:基本使用virtualenvwrapper
1. 创建一个虚拟环境:$ mkvirtualenv my_django115这会在 ~/Envs 中创建 my_django115 文件夹。2. 在虚拟环境上工作:激活虚拟环境my_django115$ workon my_django1153. 再创建一个新的虚拟环境$ mkvirtualenv my_django2virtualenvwrapper 提供环境名字的tab补全功能。当有很多环境, 并且很难记住它们的名字时,这就显得很有用。4. workon还可以任意停止你当前的环境,可以在多个虚拟环境中来回切换workon django1.15workon django2.05. 也可以手动停止虚拟环境deactivate6. 删除虚拟环境,需要先退出虚拟环境rmvirtualenv my_django115
步骤四:常用其他命令
1. 列举所有的虚拟环境。lsvirtualenv2. 导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages 。
cdvirtualenv3. 和上面的类似,但是是直接进入到 site-packages 目录中。cdsitepackages4. 显示 site-packages 目录中的内容。lssitepackages完整官网介绍:https://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html
图解
二、Mac下创建pycharm
第二步:
第三步:此时这里的Django环境是虚拟环境的版本
第四步:检查venv下的django版本
第五步:添加已创建的虚拟环境venv的python解释器,至pycharm,用于创建1.98指定版本的django
第六步:成功启动1.98版本的django
赞 (0)