Python虚拟环境(venv)的全面使用指南

 更新时间:2026年03月24日 09:32:31   作者:独隅  
Python 虚拟环境(Virtual Environment)是 Python 开发中不可或缺的隔离机制,本指南基于官方 venv 模块,结合跨平台实战经验,从背景历史到进阶技巧,全方位解析虚拟环境的创建、管理、依赖处理及避坑指南,需要的朋友可以参考下

摘要

Python 虚拟环境(Virtual Environment)是 Python 开发中不可或缺的隔离机制。它允许你在同一台机器上为不同项目创建独立的隔离的 Python 运行环境,每个环境拥有自己的解释器、第三方库和配置文件,彻底有效解决了**依赖地狱(依赖冲突)**问题。本指南基于官方 venv 模块,结合跨平台实战经验,从背景历史到进阶技巧,全方位解析虚拟环境的创建、管理、依赖处理及避坑指南。

一、背景、发展历史与方向

1. 为什么需要虚拟环境?

在 Python 开发中,不同项目往往依赖不同版本的库:

  • 项目 A:需要 Django 3.2
  • 项目 B:需要 Django 4.0
  • 全局环境:只能安装一个版本,导致冲突。

虚拟环境的作用

  1. 项目隔离:每个项目拥有独立的依赖树,互不干扰、确保不同项目的依赖互不干扰。
  2. 避免污染:防止全局 Python 环境被实验性包破坏、避免全局环境被污染,保持系统 Python 的稳定性。
  3. 依赖管理:通过 requirements.txt 精确记录和复现环境、通过 requirements.txt 轻松在其他机器上复现完全一致的开发环境。
  4. 安全测试:放心测试新库,不影响其他项目或系统工具、可以在隔离环境中安全地测试新库或升级操作,失败只需删除环境即可,不影响系统

2. 发展历史

  • 早期痛点: 在虚拟环境工具出现之前,所有 Python 项目共享系统全局的 site-packages。如果项目 A 需要 Django 2.0,而项目 B 需要 Django 4.0,开发者将无法在同一台机器上同时开发这两个项目,强行安装会导致版本冲突(Dependency Hell)。
  • virtualenv 时代: 早期社区主要依赖第三方工具 virtualenv 来解决这一问题,它功能强大但需要额外安装。
  • venv 的诞生 (Python 3.3+): 为了标准化和简化流程,Python 3.3 引入了内置模块 venv (PEP 405)。它成为了官方推荐的标准工具,无需额外安装即可使用,轻量且稳定。
  • 现代生态: 如今,venv 是日常开发的首选,而 conda 则在数据科学领域占据主导,poetrypipenv 等工具则在依赖管理层面提供了更高级的封装。
  • Python 2.x 时代:主要依赖第三方工具 virtualenv(由 Ian Bicking 开发)。
  • Python 3.3+ (2012):PEP 405 被接受,venv 模块作为标准库内置,无需额外安装。
  • Python 3.4+ensurepip 模块加入,虚拟环境默认包含 pip
  • 现代趋势venv 成为官方推荐标准,virtualenv 主要用于兼容旧版本或特殊需求;conda 在数据科学领域流行。

3. 发展方向

  • 更轻量级:减少基础镜像大小。
  • 更好的集成:与 IDE(VS Code, PyCharm)深度整合。
  • 可复现性:结合 pip-tools, Poetry, Pipenv 等工具实现更严格的依赖锁定。
  • 标准化: 成为所有 Python 项目的标准配置(通常命名为 .venv)。
  • 集成化: 现代 IDE (VS Code, PyCharm) 自动识别并集成 venv 管理。
  • 轻量化: 相比 Conda,venv 更专注于 Python 包本身,启动更快,占用更小。

二、基本语法结构与跨平台操作

1. 核心命令速查表

操作Windows (CMD/PowerShell)macOS / Linux
创建环境python -m venv .venvpython3 -m venv .venv
激活环境.venv\Scripts\activatesource .venv/bin/activate
退出环境deactivatedeactivate
安装包pip install <package>pip install <package>
查看已安装包pip listpip list
导出依赖pip freeze > requirements.txtpip freeze > requirements.txt
安装依赖pip install -r requirements.txtpip install -r requirements.txt
删除环境rmdir /s /q .venvrm -rf .venv

命名约定:业界通常将虚拟环境命名为 .venv(加点表示隐藏目录),并在 .gitignore 中忽略它。

2. 详细操作步骤

Step 1: 检查 Python 版本

确保安装了 Python 3.3+(推荐 3.8+)。

python3 --version
# 或 Windows
python --version

Step 2: 创建虚拟环境

Python 3.3+ 内置 venv 模块,无需安装。

通用命令:

python3 -m venv <环境名称>

注:在 Windows 上,如果 python3 不可用,请尝试 python

常用命名约定:

  • .venv: 最推荐的命名,以 . 开头表示隐藏文件夹,保持目录整洁。
  • venv: 传统命名。
  • env: 简短命名。

示例:

mkdir my_project
cd my_project
python3 -m venv .venv

进入项目目录,执行创建命令:

# macOS/Linux
python3 -m venv .venv
# Windows
python -m venv .venv

目录结构解析

  • bin/ (Unix) 或 Scripts/ (Windows):存放激活脚本和解释器。
  • Lib/lib/:存放安装的第三方库。
  • pyvenv.cfg:配置文件,指向基础 Python 解释器。

Step 3: 激活虚拟环境 (关键步骤)

激活后,命令行提示符前会出现环境名称(如 (.venv)),此时所有的 pythonpip 命令都指向虚拟环境内部。
macOS / Linux:

source .venv/bin/activate

Windows (CMD):

.venv\Scripts\activate

Windows (PowerShell):

.venv\Scripts\Activate.ps1

注:若 PowerShell 提示执行策略错误,可能需要以管理员身份运行需运行 Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

激活成功标志:命令行前出现 (.venv) 前缀。

(.venv) user@machine:~/my_project$ 

Step 4: 管理与安装包

激活后,pythonpip 命令自动指向虚拟环境内部。

# 安装单个包
pip install requests
# 安装多个包
pip install requests pandas numpy
# 安装指定版本
pip install django==3.2.12
# 查看已安装包
pip list
# 升级 pip
pip install --upgrade pip

Step 5: 导出与复现依赖

导出依赖文件

pip freeze > requirements.txt

复现(从文件安装依赖)(在新机器或新环境中):

pip install -r requirements.txt

提示:国内用户可使用镜像源加速:pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple

Step 6: 退出虚拟环境

退出:完成工作后,随时可以退出:

deactivate

退出后,命令行提示符恢复正常,pythonpip 回归系统全局版本。

Step 7: 删除虚拟环境

虚拟环境只是一个文件夹,删除它即删除了环境。

确保先退出环境: deactivate

macOS / Linux:

rm -rf .venv

Windows (CMD):

rmdir /s /q .venv

Windows (PowerShell):

Remove-Item -Recurse -Force .venv

三、进阶使用与实际场景

1. 指定 Python 版本创建环境

若系统安装了多个 Python 版本(如 3.8, 3.9, 3.10),可指定解释器:

# 使用 Python 3.8 创建环境
python3.8 -m venv .venv38
# 激活后检查版本
source .venv38/bin/activate
python --version  # 输出: Python 3.8.x

2. 继承系统包 (System Site Packages)

默认情况下,虚拟环境无法访问全局安装的包。如果需要(例如全局安装了某些难以编译的系统级库),可以使用 --system-site-packages
默认情况下,虚拟环境隔离系统包。若需访问系统已安装的全局包(如某些系统工具依赖):

python3 -m venv --system-site-packages .venv

慎用:可能破坏隔离性。
警告:这会破坏环境的纯净性,通常不推荐,除非明确知道自己在做什么。

3. 不带 pip 的环境

用于构建极度精简的环境(较少见)。
极简模式,手动安装 pip:

python3 -m venv --without-pip .venv

4. 实际场景:Django 项目开发

# 1. 创建项目目录
mkdir my_blog && cd my_blog
# 2. 创建并激活环境
# macOS/Linux
python3 -m venv .venv
source .venv/bin/activate
# Windows CMD
# python -m venv .venv
# .venv\Scripts\activate.bat
# Windows PowerShell
# python -m venv .venv
# .venv\Scripts\Activate.ps1
# 3. 升级 pip (好习惯,避免安装旧版包)
pip install --upgrade pip
# 4. 安装 Django
pip install django==4.2
# 5. 创建 Django 项目 (注意末尾的 . 表示在当前目录)
django-admin startproject config .
# 6. 【可选】创建第一个 App (这才是开发步骤,而不是重复 startproject)
python manage.py startapp blog
# 7. 开发阶段...
# (在此阶段你可能还会安装其他包,例如: pip install Pillow)
# echo "Hello World" >> blog/views.py  (模拟写代码)
# 8. 开发完成后,统一导出所有依赖 (覆盖之前的记录)
pip freeze > requirements.txt
# 9. 运行开发服务器测试
python manage.py runserver
# 10. 完成工作,退出环境
deactivate
# ==========================================
# 同事协作场景 (拉取代码后)
# ==========================================
# 同事只需运行:
git clone <你的仓库地址>
cd my_blog
# 1. 创建环境
python3 -m venv .venv
# 2. 激活环境
source .venv/bin/activate  # Windows 对应用户的命令
# 3. 一键还原所有依赖 (包括 Django 和你后来加的 Pillow 等)
pip install -r requirements.txt
# 4. 运行
python manage.py runserver

5. 实际场景:数据科学环境

# 创建专门用于数据分析的环境
python3 -m venv data-env
source data-env/bin/activate
# 安装重型科学计算库
pip install numpy pandas scikit-learn matplotlib jupyter
# 启动 Jupyter Notebook
jupyter notebook

6: IDE 集成 (VS Code / PyCharm)

  • VS Code: 打开项目后,右下角点击 Python 版本号,选择 .venv/bin/python,IDE 会自动识别并使用该环境进行 linting 和调试。
  • PyCharm: 新建项目时直接选择 “New environment using Virtualenv”,IDE 会自动处理创建和激活过程。

四、致命陷阱与避坑指南

陷阱 1:忘记激活环境

这是新手最常犯的错误。在未激活环境下安装的包会进入全局环境,导致虚拟环境失去意义。

  • 检查方法: 看命令行前是否有 (.venv) 前缀,或运行 which python (Linux/Mac) / where python (Windows) 确认路径是否指向 .venv 目录。

现象:安装包到了全局环境,项目运行时却报错 ModuleNotFoundError
解决:养成习惯,进入项目目录第一件事就是检查命令行是否有 (.venv) 前缀。

which python  # Unix
where python  # Windows
# 确认路径指向 .venv 目录

陷阱 2:将虚拟环境提交到 Git

虚拟环境包含大量二进制文件和特定路径配置,体积大且不可移植。
现象:仓库体积巨大,且在其他机器上因路径硬编码无法运行。
解决:务必在 .gitignore 中添加:

.venv/
venv/
env/
*.pyc
__pycache__/

陷阱 3:移动虚拟环境

虚拟环境中的许多脚本(如 activate 和 Shebang 行)包含绝对路径
现象:将整个 .venv 文件夹复制到另一台电脑或不同路径,导致无法激活。
原因:虚拟环境中的脚本(如 activate)和解释器路径是硬编码的绝对路径。
解决不要移动环境。如果项目移动了,删除旧的 .venv,在新位置重新创建并安装依赖。在新位置重新创建环境并 pip install -r requirements.txt

陷阱 4:Windows PowerShell 激活失败

在 PowerShell 中运行 .venv\Scripts\activate 可能会报错:“在此系统上禁止运行脚本”。
现象:运行 Activate.ps1 提示“在此系统上禁止运行脚本”。
解决 - 1: 以管理员身份运行 PowerShell,执行 Set-ExecutionPolicy RemoteSigned,或者直接使用 .venv\Scripts\Activate.ps1
解决 - 2:以管理员身份打开 PowerShell,执行:

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

陷阱 5:依赖版本冲突

现象requirements.txt 中未锁定具体版本(如只写了 requests 而非 requests==2.28.0),导致不同时间安装版本不一致。
解决:始终使用 pip freeze 生成带版本号的文件,或使用 pip-tools 进行更精细的管理。

陷阱 6:混淆pip和pip3

现象:在某些 Linux 发行版中,pip 可能指向 Python 2,而 pip3 指向 Python 3。
解决:在虚拟环境激活后,直接使用 pip 即可(它会自动指向环境内的正确版本)。若未激活,建议使用 python3 -m pip

陷阱 7: 混淆requirements.txt和setup.py

  • requirements.txt: 用于锁定应用运行的确切环境(包含所有依赖及其版本),主要用于部署和开发环境复现。
  • setup.py / pyproject.toml: 用于定义库本身的元数据和依赖关系,主要用于发布包到 PyPI。
  • 建议: 应用项目主要维护 requirements.txt

五、最佳实践总结

  1. 一文一环境:每个独立项目都必须有专属虚拟环境。
  2. 命名规范:统一使用 .venv 作为目录名,方便 IDE 自动识别。
  3. 忽略提交:确保 .gitignore 中包含虚拟环境目录。
  4. 锁定版本requirements.txt 必须包含具体版本号(==)。
  5. 定期清理:删除不再维护的项目的虚拟环境,释放磁盘空间。
  6. 自动化:在 CI/CD 流程中自动创建环境并安装依赖,确保测试一致性。

建议
“虚拟环境不是可选项,而是 Python 开发的标配。从今天开始,告别全局安装,拥抱隔离与纯净!”
掌握 venv 是 Python 开发者的基本功。遵循 “每个项目一个环境”“不提交环境目录”“始终记录依赖” 这三条原则,能让你的开发之路更加顺畅,避免绝大多数依赖冲突问题。

掌握 venv,你就掌握了 Python 工程化的第一把钥匙。

以上就是Python虚拟环境(venv)的全面使用指南的详细内容,更多关于Python虚拟环境venv使用的资料请关注脚本之家其它相关文章!

相关文章

  • Python 快速把多个元素连接成一个字符串的操作方法

    Python 快速把多个元素连接成一个字符串的操作方法

    join() 方法一个用于将序列中的元素以指定的分隔符连接成一个字符串的方法,这个方法通常用于字符串操作,这篇文章主要介绍了Python 快速把多个元素连接成一个字符串的方法,需要的朋友可以参考下
    2024-06-06
  • Python定时任务工具之APScheduler使用方式

    Python定时任务工具之APScheduler使用方式

    APScheduler (advanceded python scheduler)是一款Python开发的定时任务工具。这篇文章主要介绍了Python定时任务工具--APScheduler的使用方式,需要的朋友可以参考下
    2019-07-07
  • 使用Python实现NBA球员数据查询小程序功能

    使用Python实现NBA球员数据查询小程序功能

    这篇文章主要介绍了使用Python实现NBA球员数据查询小程序功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • matplotlib如何设置坐标轴刻度的个数及标签的方法总结

    matplotlib如何设置坐标轴刻度的个数及标签的方法总结

    这里介绍两种设置坐标轴刻度的方法,一种是利用pyplot提交的api去进行设置,另一种是通过调用面向对象的api, 即通过matplotlib.axes.Axes去设置,需要的朋友可以参考下
    2021-06-06
  • python生成随机红包的实例写法

    python生成随机红包的实例写法

    在本篇文章里小编给大家整理的是关于python生成随机红包的实例写法以及相关知识点,有需要的朋友们可以学习下。
    2019-09-09
  • Python3合并两个有序数组代码实例

    Python3合并两个有序数组代码实例

    这篇文章主要介绍了Python3合并两个有序数组代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • Flask框架运用Ajax实现数据交互的示例代码

    Flask框架运用Ajax实现数据交互的示例代码

    使用Ajax技术网页应用能够快速地将增量更新呈现在用户界面上,而不需要重载刷新整个页面,这使得程序能够更快地回应用户的操作,本文将简单介绍使用AJAX如何实现前后端数据通信
    2022-11-11
  • 一文带你了解Python中pymysql的使用

    一文带你了解Python中pymysql的使用

    pymysql就是联通mysql实现python窗口与mysql数据库交互的库,十分方便操作,这篇文章将详细说明如何掌握并使用该库,感兴趣的可以了解一下
    2023-02-02
  • pycharm运行按钮灰色问题及解决

    pycharm运行按钮灰色问题及解决

    这篇文章主要介绍了pycharm运行按钮灰色问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • 详解python的xlwings库读写excel操作总结

    详解python的xlwings库读写excel操作总结

    这篇文章主要介绍了详解python的xlwings库读写excel操作总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02

最新评论