在真实项目中,你很少只面对“一个 Python 版本”。
- 老项目卡在 3.8
- 新框架要求 3.11+
- 某些工具链只支持 3.10
- CI 里还要做多版本测试
如果你还在反复卸载、重装、改 PATH,那么是时候认识一下 pyenv。
- 官方仓库: https://github.com/pyenv/pyenv
- Windows 版本:https://github.com/pyenv-win/pyenv-win
本文将系统讲清:
- pyenv 是什么
- 它是如何工作的
- 多平台安装重点
- 常用命令清单
- Windows 下的 pyenv-win
- 关键注意事项
一、pyenv 是什么?
pyenv 是一个专注于“Python 版本管理”的轻量工具。
它的设计理念非常 Unix 风格:
- 只做一件事 —— 管理 Python 版本
- 不管理虚拟环境
- 不修改系统 Python
- 不依赖 Python 自身运行
它最核心的能力是:
- 支持安装多个 Python 版本(CPython / PyPy 等)
- 支持全局 / 项目级 / 会话级 切换版本
- 支持多版本并行查找(对 tox 很有用)
- 通过 shim 机制“透明劫持” python / pip
二、pyenv 的核心原理:shim + PATH 劫持
理解 pyenv 的关键在于两个词:
1️⃣ PATH 查找顺序
当你输入:
python
Shell 会按 PATH 从左到右查找可执行文件。
例如:
/usr/local/bin:/usr/bin:/bin
谁在前面谁优先。
2️⃣ shim 机制
pyenv 会在 PATH 前面插入:
~/.pyenv/shims
这个目录里并不是真正的 python,而是“转发程序”。
流程是:
python -> shim -> pyenv -> 正确版本的 python
pyenv 会按如下优先级决定使用哪个版本:
- 环境变量 PYENV_VERSION
- 当前目录 .python-version
- 父目录 .python-version
- 全局 version 文件
- system(系统默认)
这种设计的好处:
- 不改系统 Python
- 不破坏已有环境
- 切换极其干净
三、安装方式(Linux / macOS)
推荐方式
curl -fsSL https://pyenv.run | bash
或使用 Git:
git clone https://github.com/pyenv/pyenv.git ~/.pyenv
macOS(推荐 Homebrew)
brew update
brew install pyenv
安装开发版:
brew install pyenv --head
Shell 配置(关键步骤)
必须把 pyenv 注入 PATH。
以 Bash 为例:
export PYENV_ROOT="$HOME/.pyenv"
export PATH="$PYENV_ROOT/bin:$PATH"
eval "$(pyenv init - bash)"然后重启 shell:
exec "$SHELL"
四、Windows 用户:使用 pyenv-win
pyenv 官方不支持原生 Windows。
Windows 用户应使用:
👉 https://github.com/pyenv-win/pyenv-win
它是移植版本,安装的是 Windows 原生 Python。
PowerShell 安装:
Invoke-WebRequest -UseBasicParsing -Uri "https://raw.githubusercontent.com/pyenv-win/pyenv-win/master/pyenv-win/install-pyenv-win.ps1" -OutFile "./install-pyenv-win.ps1"; &"./install-pyenv-win.ps1"
重启终端后验证:
pyenv --version
Windows 重要注意事项
- 必须正确设置 PATH:
C:\Users\用户名\.pyenv\pyenv-win\bin C:\Users\用户名\.pyenv\pyenv-win\shims - 关闭 Windows 自带 Python 启动器:
设置 → 应用执行别名 → 关闭 Python - VSCode 需要重启
五、常用命令清单(必会)
查看帮助
pyenv
pyenv install --help
查看版本
pyenv versions # 已安装版本
pyenv version # 当前使用版本
pyenv install -l # 所有可安装版本
安装 Python
pyenv install 3.14.3
查看安装日志:
pyenv install -v 3.14.3
安装指定版本:
pyenv install 3.13.4<br>切换版本
全局(所有项目)
pyenv global 3.11.8
当前项目
pyenv local 3.11.8
会生成:
.python-version
当前会话
pyenv shell 3.11.8
多版本并行
pyenv global 3.11 3.12
按顺序查找。
卸载版本
pyenv uninstall 3.8.18
关键命令
pyenv which python
pyenv exec pip install flask
pyenv rehash
pyenv latest 3.10
六、pyenv 不做什么?
很多人误解 pyenv 是虚拟环境工具。
它不是。
它:
- ❌ 不管理 virtualenv
- ❌ 不管理依赖
- ❌ 不自动创建 venv
如需虚拟环境:
- 使用 venv
- 或安装插件:pyenv-virtualenv
七、版本选择优先级总结
当你运行 python 时:
- PYENV_VERSION
- 当前目录 .python-version
- 父目录
- 全局设置
- system
system 表示:
使用 PATH 中 shim 后面的 Python
八、升级与卸载
Homebrew 升级
brew upgrade pyenv
Git 升级
cd $(pyenv root)
git pull
卸载
删除 shell 配置 + 删除目录:
rm -rf $(pyenv root)
九、常见坑位总结
1️⃣ 忘记执行 rehash
安装包后找不到命令:
pyenv rehash
2️⃣ PATH 顺序错误
shims 必须在最前面。
3️⃣ macOS 编译依赖缺失
先安装构建依赖,否则 Python 安装失败。
4️⃣ Windows Python Launcher 冲突
必须关闭。
5️⃣ IDE 识别错误
重新选择解释器路径:
~/.pyenv/versions/<version>/bin/python
十、什么时候选 pyenv?什么时候选 Conda?
| 场景 | 推荐 |
|---|---|
| 纯 Python 项目 | pyenv |
| 多 Python 版本切换 | pyenv |
| 科学计算 / 多语言 | Conda |
| 简单清爽 | pyenv |
如果你只是想:
优雅地管理多个 Python 版本
pyenv 是最轻量、最干净的选择。
十一、总结
pyenv 的价值在于:
- 不干扰系统
- 多版本切换干净
- 设计简单
- 插件机制灵活
- 适合 CI / tox / 多版本测试
它的核心思想不是“帮你做很多事”,而是:
把 Python 版本问题彻底拆解干净。
如果你还在手动改 PATH、装多个解释器冲突,那么 pyenv 是一次非常值得的升级。
参考资料
- 官方仓库:https://github.com/pyenv/pyenv
- Windows 版本:https://github.com/pyenv-win/pyenv-win
文章评论