火柴人战争遗产3
413.8MB · 2026-02-21
本文档面向 Python 开发新手,详细讲解如何通过 pyenv(管理 Python 解释器版本)和 venv(Python 内置虚拟环境)的组合,实现不同项目的 Python 版本隔离、依赖版本隔离,彻底解决“一个环境跑所有项目导致的版本冲突”问题。
~/.pyenv/versions/;.venv),包含专属的 Python 解释器、pip 和依赖包;| 工具 | 解决的问题 |
|---|---|
| pyenv | 不同项目的 Python 解释器版本差异 |
| venv | 同一 Python 版本下的依赖包版本冲突 |
| pyenv+venv | 兼顾版本与依赖的双重隔离,适配所有项目场景 |
Windows 建议使用 WSL 或 pyenv-win 分支:
github.com/pyenv-win/p…
在 PowerShell 中安装 pyenv-win。
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"
重新打开 PowerShell
运行 pyenv --version 检查安装是否成功。
运行 pyenv install -l 以查看 pyenv-win 支持的 Python 版本列表
运行 pyenv install <version> 来安装支持的版本
运行 pyenv global <version>,将 Python 版本设置为全局版本
检查你使用的是哪个 Python 版本及其路径
> pyenv version
<version> (set by pathto.pyenvpyenv-win.python-version)
检查一下 Python 是否正常工作
> python -c "import sys; print(sys.executable)"
pathto.pyenvpyenv-winversions<version>python.exe
以两个示例项目为例:
# 1. 查看可安装的 Python 版本
pyenv install --list | grep "3.9" # 过滤 3.9 系列版本
pyenv install --list | grep "3.11" # 过滤 3.11 系列版本
# 2. 安装所需版本(建议加 -v 查看编译日志)
pyenv install -v 3.9.19
pyenv install -v 3.11.8
# 3. 验证已安装版本
pyenv versions # 输出包含 3.9.19、3.11.8 即为成功
# 创建项目目录
mkdir -p ~/python-projects/projectA
cd ~/python-projects/projectA
# 为当前项目设置 pyenv 局部 Python 版本(生成 .python-version 文件)
pyenv local 3.9.19
# 验证版本(此时 python3 已指向 pyenv 管理的 3.9.19)
python3 --version # 输出 Python 3.9.19
# 创建虚拟环境(命名为 .venv,隐藏目录更整洁)
python3 -m venv .venv
# 激活虚拟环境(Linux/macOS)
source .venv/bin/activate
# Windows 激活命令:
# cmd:.venvScriptsactivate.bat
# PowerShell:.venvScriptsActivate.ps1
激活成功后,终端提示符前会出现 (.venv) 标识,表明已进入隔离环境。
# 安装指定版本的 pandas
pip install pandas==1.5.0
# 验证依赖版本
python -c "import pandas; print(pandas.__version__)" # 输出 1.5.0
# 导出依赖到 requirements.txt(必备,方便协作/复用)
pip freeze > requirements.txt
# 退出虚拟环境
deactivate
# 重新进入项目并激活(后续开发时)
cd ~/python-projects/projectA
source .venv/bin/activate
操作逻辑与项目 A 一致,仅替换版本:
# 1. 创建目录并切换 Python 版本
mkdir -p ~/python-projects/projectB
cd ~/python-projects/projectB
pyenv local 3.11.8
python3 --version # 输出 Python 3.11.8
# 2. 创建并激活 venv 环境
python3 -m venv .venv
source .venv/bin/activate
# 3. 安装依赖并导出清单
pip install pandas==2.0.0
python -c "import pandas; print(pandas.__version__)" # 输出 2.0.0
pip freeze > requirements.txt
# 切换到项目 A
cd ~/python-projects/projectA
source .venv/bin/activate
python -c "import pandas; print(pandas.__version__)" # 1.5.0
# 切换到项目 B(先退出 A 的环境,再激活 B)
deactivate
cd ~/python-projects/projectB
source .venv/bin/activate
python -c "import pandas; print(pandas.__version__)" # 2.0.0
拿到包含 requirements.txt 的项目后,快速复现环境:
# 1. 克隆/进入项目目录
cd ~/python-projects/projectA
# 2. 切换项目指定的 Python 版本
pyenv local 3.9.19
# 3. 创建并激活 venv 环境
python3 -m venv .venv
source .venv/bin/activate
# 4. 一键安装所有依赖
pip install -r requirements.txt
| 操作 | 命令 |
|---|---|
| 查看 pyenv 已装版本 | pyenv versions |
| 切换全局 Python 版本 | pyenv global 3.11.8 |
| 切换局部 Python 版本 | pyenv local 3.9.19 |
| 创建 venv 环境 | python3 -m venv .venv |
| 激活 venv 环境 | source .venv/bin/activate |
| 退出 venv 环境 | deactivate |
| 导出依赖清单 | pip freeze > requirements.txt |
| 安装依赖清单 | pip install -r requirements.txt |
| 删除 venv 环境 | rm -rf .venv(Linux/macOS) |
.venv 目录包含大量依赖文件,体积大且环境相关,需在 .gitignore 中添加:
# .gitignore 内容
.venv/
__pycache__/
*.pyc
创建 venv 时,使用 pyenv 切换后的 python3 命令,确保 venv 环境的 Python 版本与项目要求一致。
必须在项目根目录执行 source .venv/bin/activate,若进入子目录,可使用绝对路径:
source ~/python-projects/projectA/.venv/bin/activate
PATH 环境变量中 pyenv 的 shims 目录优先级不足;~/.zshrc/~/.bashrc 最后,执行 source ~/.zshrc 重新生效。sudo pip,导致权限混乱;pip install(无需 sudo),若已有权限问题,删除 .venv 重新创建。解决:以管理员身份运行 PowerShell,执行:
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser
pyenv 负责管理 Python 解释器版本,解决“不同项目用不同 Python 版本”的问题;venv 负责创建项目专属依赖环境,解决“同一 Python 版本下依赖冲突”的问题;pyenv 切换 Python 版本 → venv 创建虚拟环境 → 激活环境 → 安装依赖,实现项目环境完全隔离;requirements.txt 导出/安装依赖,可保证开发、协作、部署环境的一致性。