首頁  >  文章  >  後端開發  >  詳解pyenv指令管理多個Python版本方法

詳解pyenv指令管理多個Python版本方法

高洛峰
高洛峰原創
2017-03-28 09:30:451666瀏覽

這篇文章主要介紹了pyenv指令管理多個Python版本依賴環境的相關資料,需要的朋友可以參考下

從接觸Python以來,一直都是採用virtualenv 和virtualenvwrapper 來管理不同專案的依賴環境,透過workon 、 mkvirtualenv 等指令進行虛擬環境切換,很是愉快。

然而,最近想讓專案能相容於更多的Python版本,例如至少同時相容於Python2.7 和Python3.3+ ,就發現採用之前的方式行不通了。的問題在於,在本機同時

安裝

Python2.7 和Python3 後,即使分別針對兩個Python版本安裝了virtualenv 和virtualenvwrapper ,也無法讓兩個Python版本的workon 、 mkvirtualenv 指令同時生效。另外一方面,要想在本機安裝多個Python版本,會發現安裝的成本都比較高,實作方式也不夠優雅。方案,那就是pyenv 。 如果要講解pyenv 的工作原理,基本上採用一句話就可以概括,那就是:修改系統環境

變數

PATH 。相信大家都不陌生,裡麵包含了一串由冒號分隔的路徑,例如/usr/local/bin:/usr/bin:/bin 。就會在PATH 的所有路徑中從左到右依序尋找對應的指令。最前面插入一個$(pyenv root)/shims 目錄。更多細節,可以查看pyenv 的文檔介紹及其原始碼實作。方式,原因主要有兩點:

透過pyenv-installer 可一鍵安裝pyenv 全家桶,後續也可以很方便地實現一鍵升級;

pyenv-installer 的安裝方式基於GitHub ,可保證總是使用到最新版本的pyenv ,並且Python 版本庫也是最新和最全的。

install && config

透過以下指令安裝 pyenv 全家桶。

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

#內容除了包含pyenv 以外,還包含以下插件:

pyenv-doctor

pyenv-installer

pyenv-update



pyenv-virtualenv

pyenv-which-ext

安裝完成後, pyenv 指令還沒有加進系統的環境變量,需要將以下內容加到~/.zshrc 中,然後執行source ~/.zshrc 。

pyenv lets you easily switch between multiple versions of Python. It's simple, unobtrusive, and follows the UNIX tradition of single-purpose tools that do one thing well.

This project was forked from rbenv and ruby-build , and modified for Python.
    完成以上操作後, pyenv 就安裝完成了。
  1. export PATH=$HOME/.pyenv/bin:$PATH
    eval "$(pyenv init -)"
    eval "$(pyenv virtualenv-init -)"

    如果不確定 pyenv 的環境是否安裝正常,可以透過 pyenv doctor 指令對環境進行偵測。

    $ pyenv -v
    pyenv 1.0.8
  2. 透過偵測,可以發現本機環境可能存在的問題,例如,從以上輸出可以看出,本地的 OpenSSL development header 還沒有安裝。根據提示的問題,逐一進行修復,直到檢測不再出現問題為止。
  3. update
  4. 透過 pyenv update 指令,可以更新 pyenv 全家桶的所有內容。

    $ pyenv doctor
    Cloning /Users/Leo/.pyenv/plugins/pyenv-doctor/bin/.....
    Installing python-pyenv-doctor...
    
    BUILD FAILED (OS X 10.12.3 using python-build 20160602)
    
    Last 10 log lines:
    checking for memory.h... yes
    checking for strings.h... yes
    checking for inttypes.h... yes
    checking for stdint.h... yes
    checking for unistd.h... yes
    checking openssl/ssl.h usability... no
    checking openssl/ssl.h presence... no
    checking for openssl/ssl.h... no
    configure: error: OpenSSL development header is not installed.
    make: *** No targets specified and no makefile found. Stop.
    Problem(s) detected while checking system.
  5. pyenv的核心使用方法

  6. pyenv 的主要功能如下:
  7. $ pyenv -h

    Usage: pyenv []
  8. Some useful pyenv commands are:
       commands    List all available pyenv commands
       local       Set or show the local application-specific Python version
       global      Set or show the global Python version
       shell       Set or show the shell-specific Python version
       install     Install a Python version using python-build
       uninstall   Uninstall a specific Python version
       rehash      Rehash pyenv shims (run this after installing executables)
       version     Show the current Python version and its origin
       versions    List all Python versions available to pyenv
       which       Display the full path to an executable
       whence      List all Python versions that contain the given executable

    See `pyenv help ' for information on a specific command.
    For full documentation, see: https://github.com/yyuu/pyenv#readme

    查看所有可安装的 Python 版本

    $ pyenv install --list
    Available versions:
     2.1.3
     ...
     2.7.12
     2.7.13
     ...
     3.5.3
     3.6.0
     3.6-dev
     3.6.1
     3.7-dev

    需要注意的是,如果是采用 brew 命令安装的 pyenv ,可能会发现 Python 版本库中没有最新的 Python 版本。所以建议还是通过 GitHub 源码方式安装 pyenv 。

    安装指定版本的 Python 环境

    $ pyenv install 3.6.0
    Downloading Python-3.6.0.tar.xz...
    -> https://www.python.org/ftp/python/3.6.0/Python-3.6.0.tar.xz
    Installing Python-3.6.0...
    Installed Python-3.6.0 to /Users/Leo/.pyenv/versions/3.6.0

    查看当前系统中所有可用的 Python 版本

    $ pyenv versions
    * system (set by /Users/Leo/.pyenv/version)
     2.7.13
     3.6.0

    切换 Python 版本

    pyenv 可以从三个维度来管理 Python 环境,简称为: 当前系统 、 当前目录 、 当前shell 。这三个维度的优先级从左到右依次升高,即 当前系统 的优先级最低、 当前shell 的优先级最高。

    如果想修改系统全局的Python环境,可以采用 pyenv global PYTHON_VERSION 命令。该命令执行后会在 $(pyenv root) 目录(默认为 ~/.pyenv )中创建一个名为 version 的文件(如果该文件已存在,则修改该文件的内容),里面记录着系统全局的Python版本号。

    $ pyenv global 2.7.13
    $ cat ~/.pyenv/version
    2.7.13
    $ pyenv version
    2.7.13 (set by /Users/Leo/.pyenv/version)
    
    $ pyenv global 3.6.0
    $ cat ~/.pyenv/version
    3.6.0
    $ pyenv version
    3.6.0 (set by /Users/Leo/.pyenv/version)

    通常情况下,对于特定的项目,我们可能需要切换不同的Python环境,这个时候就可以通过 pyenv local PYTHON_VERSION 命令来修改 当前目录 的Python环境。命令执行后,会在当前目录中生成一个 .python-version 文件(如果该文件已存在,则修改该文件的内容),里面记录着当前目录使用的Python版本号。

    $ cat ~/.pyenv/version
    2.7.13
    $ pyenv local 3.6.0
    $ cat .python-version
    3.6.0
    $ cat ~/.pyenv/version
    2.7.13
    $ pyenv version
    3.6.0 (set by /Users/Leo/MyProjects/.python-version)
    $ pip -V
    pip 9.0.1 from /Users/Leo/.pyenv/versions/3.6.0/lib/python3.6/site-packages (python 3.6)

    可以看出,当前目录中的 .python-version 配置优先于系统全局的 ~/.pyenv/version 配置。

    另外一种情况,通过执行 pyenv shell PYTHON_VERSION 命令,可以修改 当前shell 的Python环境。执行该命令后,会在当前 shell session (Terminal窗口)中创建一个名为 PYENV_VERSION 的环境变量,然后在 当前shell 的任意目录中都会采用该环境变量设定的Python版本。此时, 当前系统 和 当前目录 中设定的Python版本均会被忽略。

    $ echo $PYENV_VERSION
    
    $ pyenv shell 3.6.0
    $ echo $PYENV_VERSION
    3.6.0
    $ cat .python-version
    2.7.13
    $ pyenv version
    3.6.0 (set by PYENV_VERSION environment variable)

    顾名思义, 当前shell 的Python环境仅在当前shell中生效,重新打开一个新的shell后,该环境也就失效了。如果想在 当前shell 中取消shell级别的Python环境,采用 unset 命令重置 PYENV_VERSION 环境变量即可。

    $ cat .python-version
    2.7.13
    $ pyenv version
    3.6.0 (set by PYENV_VERSION environment variable)
    
    $ unset PYENV_VERSION
    $ pyenv version
    2.7.13 (set by /Users/Leo/MyProjects/.python-version)

    管理多个依赖库环境

    经过以上操作,我们在本地计算机中就可以安装多个版本的 Python 运行环境,并可以按照实际需求进行灵活地切换。然而,很多时候在同一个 Python 版本下,我们仍然希望能根据项目进行环境分离,就跟之前我们使用 virtualenv 一样。

    在 pyenv 中,也包含这么一个插件, pyenv-virtualenv ,可以实现同样的功能。

    使用方式如下:

    $ pyenv virtualenv PYTHON_VERSION PROJECT_NAME

    其中, PYTHON_VERSION 是具体的Python版本号,例如, 3.6.0 , PROJECT_NAME 是我们自定义的项目名称。比较好的实践方式是,在 PROJECT_NAME 也带上Python的版本号,以便于识别。

    现假设我们有 XDiff 这么一个项目,想针对 Python 2.7.13 和 Python 3.6.0 分别创建一个虚拟环境,那就可以依次执行如下命令。

    $ pyenv virtualenv 3.6.0 py36_XDiff
    $ pyenv virtualenv 2.7.13 py27_XDiff

    创建完成后,通过执行 pyenv virtualenvs 命令,就可以看到本地所有的项目环境。

    $ pyenv virtualenvs
     2.7.13/envs/py27_XDiff (created from /Users/Leo/.pyenv/versions/2.7.13)
    * 3.6.0/envs/py36_XDiff (created from /Users/Leo/.pyenv/versions/3.6.0)
     py27_XDiff (created from /Users/Leo/.pyenv/versions/2.7.13)
     py36_XDiff (created from /Users/Leo/.pyenv/versions/3.6.0)

    通过这种方式,在同一个Python版本下我们也可以创建多个虚拟环境,然后在各个虚拟环境中分别维护依赖库环境。

    例如, py36_XDiff 虚拟环境位于 /Users/Leo/.pyenv/versions/3.6.0/envs 目录下,而其依赖库位于 /Users/Leo/.pyenv/versions/3.6.0/lib/python3.6/site-packages 中。

    $ pip -V
    pip 9.0.1 from /Users/Leo/.pyenv/versions/3.6.0/lib/python3.6/site-packages (python 3.6)

    后续在项目开发过程中,我们就可以通过 pyenv local XXX 或 pyenv activate PROJECT_NAME 命令来切换项目的 Python 环境。

    ➜ MyProjects pyenv local py27_XDiff
    (py27_XDiff) ➜ MyProjects pyenv version
    py27_XDiff (set by /Users/Leo/MyProjects/.python-version)
    (py27_XDiff) ➜ MyProjects python -V
    Python 2.7.13
    (py27_XDiff) ➜ MyProjects pip -V
    pip 9.0.1 from /Users/Leo/.pyenv/versions/2.7.13/envs/py27_XDiff/lib/python2.7/site-packages (python 2.7)

    可以看出,切换环境后, pip 命令对应的目录也随之改变,即始终对应着当前的Python虚拟环境。

    对应的,采用 pyenv deactivate 命令退出当前项目的 Python 虚拟环境。

    如果想移除某个项目环境,可以通过如下命令实现。

    $ pyenv uninstall PROJECT_NAME

    以上便是日常开发工作中常用的 pyenv 命令,基本可以满足绝大多数依赖库环境管理方面的需求。

以上是詳解pyenv指令管理多個Python版本方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn