>  기사  >  백엔드 개발  >  pyenv 명령을 사용하여 여러 Python 버전을 관리하는 방법에 대한 자세한 설명

pyenv 명령을 사용하여 여러 Python 버전을 관리하는 방법에 대한 자세한 설명

高洛峰
高洛峰원래의
2017-03-28 09:30:451716검색

이 글에서는 주로 여러 Python 버전 종속 환경을 관리하는 pyenv 명령을 소개합니다. 정보가 필요한 친구들은

을 참고하세요. Python을 접한 이후로 항상 virtualenv와 virtualenvwrapper를 사용해 다양한 프로젝트의 종속 환경을 관리해 왔습니다. 등의 명령을 통해 가상 환경을 전환하는 것이 매우 즐겁습니다. workon 및 mkvirtualenv.

그러나 최근에는 프로젝트가 더 많은 Python 버전과 호환되도록 만들고 싶었습니다. 예를 들어 최소한 Python2.7 및 Python3.3+와 호환되지만 이전 방법으로는 가능하지 않았습니다.

Max 문제는 로컬 컴퓨터에 Python2.7과 Python3을 동시에 설치한 후 virtualenv와 virtualenvwrapper가 각각 두 Python 버전에 설치되어 있는 경우에도 마찬가지입니다. , 두 Python 버전의 workon 및 mkvirtualenv 명령은 동시에 적용할 수 없습니다. 반면, 로컬 컴퓨터에 여러 Python 버전을 설치하려는 경우 설치 비용이 상대적으로 높고 구현이 어렵다는 것을 알 수 있습니다. 다행히도 이 문제에 대한 해결책은 이미 pyenv입니다.

다음은 공식 소개입니다. >이 글에서는

기본 원리

pyenv의 작동 원리를 한 문장으로 요약하면 다음과 같습니다. is: 시스템 환경 변수 PATH 수정

시스템 환경 변수 PATH의 경우 /usr과 같이 콜론으로 구분된 경로 문자열이 포함되어 있습니다. /local/bin:/usr/bin:/bin.python이나 pip 등 시스템에서 명령이 실행될 때마다 해당 명령은 PATH의 모든 경로에서 왼쪽에서 오른쪽으로 검색됩니다. 순서대로 검색하면 왼쪽의 경로가 더 높은 우선순위를 갖습니다. pyenv가 수행하는 작업은 $(pyenv root)/shims 디렉터리를 앞에 삽입하는 것입니다. 이러한 방식으로 pyenv는 제어하여 필요한 Python 버전으로 유연하게 전환할 수 있습니다. shims 디렉터리의 Python 버전 번호 더 자세한 내용을 알고 싶다면 pyenv 및 해당 소스 코드 구현

문서를 참조하세요.

pyenv를 설치하는 방법은 여러 가지가 있는데, pyenv-installer를 권장하는 이유는 크게 두 가지입니다.

Pyenv 제품군 버킷은 pyenv를 통해 한 번의 클릭으로 설치할 수 있습니다. pyenv-installer의 설치 방법은 GitHub를 기반으로 하므로 항상 최신 버전의 pyenv를 사용할 수 있으며 Python 버전 라이브러리는 다음과 같습니다. 또한 최신이자 가장 완벽합니다. install && config

다음 명령을 통해 pyenv 제품군 버킷을 설치합니다.



콘텐츠에는 pyenv 외에도 다음 플러그인도 포함되어 있습니다.

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

    pyenv-installer
  1. pyenv-update
  2. pyenv-virtualenv
  3. pyenv- which-ext
  4. 설치가 완료된 후 pyenv 명령이 시스템 환경 변수에 추가되지 않았습니다. ~/.zshrc에 다음 내용을 추가해야 합니다. , 소스 ~/.zshrc를 실행합니다.
  5. 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가 설치됩니다.

    export PATH=$HOME/.pyenv/bin:$PATH
    eval "$(pyenv init -)"
    eval "$(pyenv virtualenv-init -)"
  6. pyenv 환경이 제대로 설치되었는지 확실하지 않은 경우 pyenv doctor 명령을 사용하여 환경을 확인할 수 있습니다.
$ pyenv -v
pyenv 1.0.8

탐지를 통해 로컬 환경에서 발생할 수 있는 문제를 찾을 수 있습니다. 예를 들어 위 출력에서 ​​볼 수 있듯이 로컬 OpenSSL 개발 헤더가 설치되지 않았습니다. 표시된 문제에 따라 문제가 더 이상 발생하지 않을 때까지 하나씩 수리하십시오.

update

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.

pyenv 핵심 사용법

pyenv의 주요 기능은 다음과 같습니다.

$ pyenv -h사용법: pyenv < 명령> [<인수>]

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으로 문의하세요.