pyenv 管理多个 Python 版本(1)

alt

引言

你是否曾希望参与一个支持多个 Python 版本的项目,但又不知道如何轻松地测试所有这些版本?你是否对 Python 的最新版本感到好奇?或许你想尝试这些新功能,但又不想冒险破坏你的开发环境。幸运的是,如果你使用 pyenv,管理多个 Python 版本并不复杂。

本文[1]将向你展示如何高效地在项目上工作,同时减少因尝试使用正确版本的 Python 而产生的困扰。

通过本文,你将学会:

  • 安装多个 Python 版本
  • 安装 Python 的最新开发版
  • 在已安装的版本间切换
  • 与 pyenv 一起使用虚拟环境
  • 自动激活不同的 Python 版本和虚拟环境

为什么要选择 pyenv?

pyenv 是一个管理多个 Python 版本的强大工具。即使你的系统中已经安装了 Python,安装 pyenv 也是有益的,因为它可以让你轻松体验新的语言特性,或者帮助参与使用不同 Python 版本的项目。此外,pyenv 还可以用来安装 Python 的预发布版本,以便你测试它们是否存在缺陷。

为什么不使用自带 Python?

“系统 Python” 指的是随操作系统一起安装的 Python。如果你使用的是 Mac 或 Linux,那么当你在终端输入 python 时,默认情况下会启动一个 Python 的交互式解释器。

那么,为什么不直接使用系统自带的 Python 呢?一种理解方式是,这个 Python 实际上是属于操作系统的。毕竟,它是随操作系统一起被安装的。这一点在你执行 which 命令时也得到了体现:

which python
/usr/bin/python

在这里,python 可供所有用户使用,很可能,这也不是您想要的 Python 版本:

$ python -V
Python 2.7.12

为什么要在系统 Python 中安装软件包时使用 sudo pip install 命令呢?这是因为你正在进行全局安装,如果另一位用户想要安装该软件包的稍早版本,这可能会引发问题。

多个版本的相同软件包可能会导致问题,这些问题往往会在你不经意间突然出现。一个常见的问题是,一个受欢迎且稳定的软件包突然在你的系统上出现问题。经过长时间的排查和搜索后,你可能会发现安装了错误的依赖版本,这让你的一天变得糟糕。

即使你的 Python 安装在 /usr/local/bin/python3,你仍然会遇到上述的权限和灵活性问题。

此外,你对于操作系统中安装的 Python 版本几乎没有控制权。如果你想使用 Python 的最新特性,而你使用的是 Ubuntu,例如,你可能就没那么幸运了。默认版本可能太旧,这意味着你得等待新操作系统的发布。

最后,一些操作系统实际上依赖于 Python 来运行。以 yum 为例,它大量依赖 Python 来执行任务。如果你安装了 Python 的新版本,并且不小心将其安装到了系统空间,你可能会严重破坏操作系统的使用能力。

那么包管理器又如何呢?

接下来合乎逻辑的选择是包管理器,比如 apt、yum、brew 或 port 等。毕竟,这是你安装大多数系统软件的方式。不幸的是,你会发现使用包管理器时会遇到一些相同的问题。

默认情况下,包管理器倾向于将软件包安装到全局系统空间而不是用户空间。这些系统级别的软件包会干扰你的开发环境,使得与他人共享工作空间变得困难。

再次,你无法控制可以安装的 Python 版本。虽然一些仓库提供了更多的选择,但默认情况下,你只能安装特定供应商在任何给定时间提供的 Python 版本。

即使你通过包管理器安装了 Python,考虑一下如果你正在开发一个软件包,并且想要支持和测试 Python 3.4 到 3.7 的不同版本。

当你在系统上输入 python3 时会发生什么?你如何快速切换不同的版本?虽然这是可行的,但过程繁琐且容易出错。更不用说,如果你想使用 PyPy、Jython 或 Miniconda,那么你可能只能放弃使用包管理器。

考虑到这些限制,让我们总结一下能够轻松灵活地安装和管理 Python 版本的标准:

  • 在你的用户空间安装 Python
  • 安装多个 Python 版本
  • 指定你确切想要的 Python 版本
  • 在已安装的版本之间切换 \

pyenv 可以让你做到所有这些,甚至更多。