pyenv 是什么?
pyenv 是一个强大的 python 版本管理工具,允许你:
- 在同一台机器上安装多个 python 版本
- 轻松切换全局或项目级的 python 版本
- 管理虚拟环境(通过 pyenv-virtualenv 插件)
- 解决不同项目对 python 版本的依赖问题
安装 pyenv
1. 安装依赖
# ubuntu/debian sudo apt update sudo apt install -y make build-essential libssl-dev zlib1g-dev \ libbz2-dev libreadline-dev libsqlite3-dev wget curl llvm \ libncursesw5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev libffi-dev liblzma-dev # centos/rhel sudo yum install gcc zlib-devel bzip2 bzip2-devel readline-devel sqlite \ sqlite-devel openssl-devel xz xz-devel libffi-devel
2. 安装 pyenv
curl https://pyenv.run | bash
3. 配置 shell
将以下内容添加到 ~/.bashrc
或 ~/.zshrc
:
export path="$home/.pyenv/bin:$path" eval "$(pyenv init --path)" eval "$(pyenv virtualenv-init -)"
应用配置:
exec "$shell" # 或 source ~/.bashrc / source ~/.zshrc
4. 验证安装
pyenv --version # 应输出类似: pyenv 2.3.0
管理 python 版本
1. 查看可安装版本
pyenv install --list
2. 安装 python 版本
# 安装指定版本 pyenv install 3.8.12 pyenv install 3.9.7 # 安装最新版本 pyenv install 3.10:latest
3. 查看已安装版本
pyenv versions # 输出示例: # system # * 3.8.12 (set by /home/user/.pyenv/version) # 3.9.7
4. 设置全局版本
pyenv global 3.9.7
5. 设置临时版本(仅当前会话)
pyenv shell 3.8.12
虚拟环境管理
1. 创建虚拟环境
# 基于当前 python 版本创建 pyenv virtualenv myenv # 基于指定 python 版本创建 pyenv virtualenv 3.8.12 myproject-env
2. 激活/停用环境
# 激活 pyenv activate myproject-env # 停用 pyenv deactivate
3. 查看所有环境
pyenv virtualenvs
4. 删除环境
pyenv virtualenv-delete myproject-env
5. 自动激活环境(项目级)
cd myproject pyenv local myproject-env # 创建 .python-version 文件
项目级 python 版本控制
1. 设置项目专用版本
cd myproject pyenv local 3.8.12 # 创建 .python-version 文件
2. 验证版本
python --version # 应输出: python 3.8.12
3. 结合虚拟环境使用
cd myproject pyenv virtualenv 3.8.12 myproject-env pyenv local myproject-env
高级技巧
1. 加速安装(使用镜像)
# 设置国内镜像(适用于中国用户) export python_build_mirror_url="https://npm.taobao.org/mirrors/python/" pyenv install 3.8.12
2. 自定义编译选项
env python_configure_opts="--enable-shared" pyenv install 3.9.7
3. 卸载 python 版本
pyenv uninstall 3.7.10
4. 更新 pyenv
pyenv update
常见问题解决
1. 安装时出现 “c compiler cannot create executables”
# 确保已安装所有依赖 sudo apt install build-essential # ubuntu/debian sudo yum groupinstall "development tools" # centos/rhel
2. 虚拟环境激活后提示符不显示环境名
# 确保在 shell 配置中正确设置了 virtualenv-init eval "$(pyenv virtualenv-init -)"
3. 安装过程中出现 ssl 错误
# 尝试使用 --patch 选项 pyenv install --patch 3.8.12 < <(curl -ssl https://github.com/python/cpython/commit/8ea6353.patch\?full_index\=1)
4. python 版本切换无效
# 检查 shell 配置是否正确加载 echo $path | grep pyenv # 应包含 pyenv 路径 # 检查当前目录是否有 .python-version 文件
最佳实践
项目规范:
- 每个项目使用独立的虚拟环境
- 在项目根目录创建
.python-version
文件 - 在 readme 中注明 python 版本要求
版本选择:
- 新项目使用受支持的稳定版本(如 3.8+)
- 旧项目保持原有版本不变
依赖管理:
# 在激活虚拟环境后 pip install pip-tools pip-compile requirements.in > requirements.txt pip-sync
ci/cd 集成:
# .gitlab-ci.yml 示例 before_script: - pyenv install 3.8.12 - pyenv global 3.8.12 - python -m venv venv - source venv/bin/activate - pip install -r requirements.txt
多版本测试:
# 测试脚本示例 for version in 3.7.10 3.8.12 3.9.7; do pyenv local $version python -m pytest tests/ done
通过本指南,你应该能够:
- 安装并配置 pyenv
- 管理多个 python 版本
- 创建和使用虚拟环境
- 为不同项目设置专用 python 环境
- 解决常见问题
建议定期运行 pyenv update
保持工具最新,并关注 pyenv github 获取最新动态。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论