pyenv技能指南

原文

初识pyenv:一个简单的Python版本管理工具。以前叫做Pythonbrew,Pyenv让你能够方便地切换全局Python版本,安装多个不同的Python版本,设置独立的某个文件夹或者工程目录特异的Python版本,同时创建Python虚拟环境(”virualenv’s“)。所有这些操作均可以在类UNIX系统的机器上(Linux和OS X)不需要依赖Python本身执行,而且它工作在用户层,不需要任何sudo操作。那么我们开始吧!

安装

按照官方的安装步骤或者使用自动安装程序来安装。如果你用的是Mac,我强烈建议通过Homebrew(免去了很多MacPorts的麻烦事儿)来安装pyenv。不管你选择哪种方式安装,在检查软件已经顺利安装之后,一定要确认你已经在你的.bashrc文件中加一行配置来是pyenv自动化。(对于Mac用户是.bash_profile)(或者其它相应的Shell便好文件,取决于你用哪种Shell,译者便好Zsh)

译者注:pyenv自动化指的是在cd到某个目录时自动启动该目录对应的Python版本

Ubuntu工作站安装脚本(复制-粘贴-安装)

这个脚本最适合Ubuntu 12.04,它默认用.bashrc来代替.bash_profile.


cd

git clone git://github.com/yyuu/pyenv.git .pyenv

echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc

echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc

echo 'eval "$(pyenv init -)"' >> ~/.bashrc

source ~/.bashrc

pyenv 安装套件

这是自动安装程序提供的一行安装脚本


curl -L https://raw.githubusercontent.com/yyuu/pyenv-installer/master/bin/pyenv-installer | bash

使用指导


~$ pyenv global

system

~$ pyenv versions

* system (set by /home/staff/jmoreira/.pyenv/version)

通常情况下你只有一个Python版本,也就是系统全局的版本。它就是以上命令显示的Python版本。pyenv使你能够扩展以上版本。我们通过安装另外一个Python版本来开始吧。例如,我们现在来为cutting edge这个目录安装一个Python版本:


~$ pyenv install 3.4.0

Installing readline-6.3...

Installed readline-6.3 to /home/staff/jmoreira/.pyenv/versions/3.4.0

Installing Python-3.4.0...

Installed Python-3.4.0 to /home/staff/jmoreira/.pyenv/versions/3.4.0

(顺便告诉你没有必要记忆这些)


pyenv install -list

能显示所有安装的Python版本。


~$ pyenv versions

* system (set by /home/staff/jmoreira/.pyenv/version)

3.4.0

pyenv现在列出了两个Python版本。要使用Python 3.4来作为全局Python我们只要:


pyenv global 3.4.0

你也可以使用pyenv来定义属于工程项目的或者本地的Python版本:


~$ pyenv global system

~$ mkdir cuting_edge

~$ cd cuting_edge/

~/cutting_edge$ pyenv local 3.4.0

~/cutting_edge$ python -V

Python 3.4.0

~/cutting_edge$ cd ..

~$ python -V

Python 2.7.6

就这么简单。

虚拟环境(virtual Environments)

对于其它使用virtualenv的用户,本地Python版本的概念可能非常熟悉。事实上,pyenv创建的本地Python版本几乎相当于一个Python虚拟环境。主要的不同是pyenv每次你创建Python版本都会完全复制一份Python解释器,而相反的virtualenv之时创建符号链接而已,通过这种方式它一支了virtualenv的文件大小的增长。如果你离不开virtualenv,有一个pyenv的插件:pyenv-virtualenv能够帮你。这个插件为pyenv实现了全功能的virtualenv:


git clone https://github.com/yyuu/pyenv-virtualenv.git ~/.pyenv/plugins/pyenv-virtualenv

source ~/.bashrc

~$ mkdir virtual_env

~$ cd virtual_env/

~/virtual_env$ pyenv virtualenv 3.4.0 venv

Ignoring indexes: https://pypi.python.org/simple/

Requirement already satisfied (use --upgrade to upgrade): setuptools in /home/staff/jmoreira/.pyenv/versions/venv/lib/python3.4/site-packages

Requirement already satisfied (use --upgrade to upgrade): pip in /home/staff/jmoreira/.pyenv/versions/venv/lib/python3.4/site-packages

Cleaning up...

~/virtual_env$ pyenv versions

* system (set by /home/staff/jmoreira/.pyenv/version)

3.4.0

lab_web

venv

这里我使用Python 3.4来创建virtualenv(注意:如果你想要通过系统全局的Python来创建一个virtualenv,那么virtualenv需要先安装在系统上)。


~/virtual_env$ pyenv activate venv

(venv) ~/virtual_env$ python -V

Python 3.4.0

(venv) ~/virtual_env$ pip list

pip (1.5.4)

setuptools (2.1)

(venv) ~/virtual_env$ pyenv deactivate

~/virtual_env

建议使用上面的最后一条命令来退出一个virtualenv。这能保证在你离开virtualenv之后pyenv仍然正常工作。

pyenv的魔法能够实现是因为它实际上重定义了你的Python命令:


~$ which python

/home/staff/jmoreira/.pyenv/shims/python

当你尝试运行Python的时候,它首先查看当前目录下的.python-version目录来决定到底哪个版本的Python该运行。如果它没有发现这个文件,那么它之后回继续查找用户级别的文件~/.pyenv/version。

基本上就这么多了。祝你使用这样一个安全有环境友好的开发方式能够开心快乐。

特别感谢Adam Pah的这些使用技巧。

    原文作者:EricTian
    原文地址: https://www.jianshu.com/p/a349a17d4596
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞