UV-python环境管理工具 入门教程

在学习使用 MCP 的时候接触到了 UV 这个环境管理工具,经过对比,发现它在诸多方面比 venv、conda 等工具更为出色,因此整理了这份简单的入门学习笔记,希望能帮助大家快速上手。

介绍

UV 是一款集 Python 版本管理、虚拟环境创建与管理、依赖安装等多功能于一体的轻量级工具,可类比为 "pyenv + virtualenv + pip-tools" 的组合。与传统工具不同,它使用 Rust 编写,这赋予了它卓越的性能,在处理依赖安装与解析时,速度可比 pip 快 10 - 100 倍 。

uv 的特点:

  1. 速度更快:相比 pip ,uv 采用 Rust 编写,性能更优。
  2. 支持 PEP 582:无需 virtualenv ,可以直接使用
  3. 兼容 pip :支持 pypackages 进行管理。 requirements.txt 和 pyproject.toml 依赖管理。
  4. 替代 venv :提供 uv venv 进行虚拟环境管理,比venv更轻量
  5. 跨平台:支持 Windows、macOS 和 Linux。

安装

方法 1:pip
使用 pip 安装(适用于已安装 pip 的系统)
复制代码
 pip install uv
方法 2:curl
使用 curl 直接安装 如果你的系统没有 pip

直接运行:

复制代码
curl https://raw.githubusercontent.com/1stG/uv/master/installer.sh | bash

这会自动下载 uv 并安装到 /usr/local/bin 。

方法 3:Windows 下的 PowerShell 安装

在 Windows 系统中,可通过 PowerShell 执行以下命令进行安装:

powershell 复制代码
irm https://raw.githubusercontent.com/1stG/uv/master/installer.ps1 | iex

安装完成后,可通过命令uv --version验证是否安装成功 。

换源

在 Windows 系统上修改 UV 的下载源,通过环境变量修改

UV 提供了 UV_PYPI_INDEX_URL环境变量来设置默认的包索引源。

设置方法:

打开 "此电脑" 或 "我的电脑",右键点击选择 "属性"。

在弹出的窗口中选择 "高级系统设置"。

在 "系统属性" 窗口中,点击 "环境变量" 按钮。

在 "系统变量" 或 "用户变量" 中点击 "新建":

变量名:UV_PYPI_INDEX_URL

变量值:设置为你想要的镜像源地址,例如 https://pypi.tuna.tsinghua.edu.cn/simple。

点击 "确定" 保存设置。

创建项目

笔者自己的理解:

​ 在传统的 venv、conda 等环境管理工具中,环境与项目相对独立,一个环境可运行多个项目代码(前提是环境匹配)。而 UV 通过在项目目录生成配置文件(.uv),实现环境与项目的便捷关联。默认情况下,进入项目目录时需手动激活环境,也可配置自动激活 。环境本质上是独立的,可在多个项目中复用。

因此,创建项目即创建环境。

复制代码
uv init project_name --python 3.12
cd project_name

我们这里示例创建一个uv项目,名字叫uv_study:

复制代码
uv init uv_study --python 3.12
cd uv_study

执行上述命令后,UV 会在当前目录下创建一个基于 Python 3.12 的虚拟环境,并生成.uv配置文件

这样,一个uv项目或者说一个uv环境就创建好了。

库管理

要想在这个环境中添加依赖库,只需要使用uv add命令即可。(当然得在对应的项目目录下)

复制代码
uv add package_name
# 等效于pip install,但是比pip更快

例如,下图是uv初始环境:

我们现在新安装一个requests库:

复制代码
uv add requests

安装完成后,uv会自动在pyproject.toml写入依赖,比传统的requirements.txt高效得多。

当然也可以删除库:

复制代码
uv remove requests

运行项目

我们简单修改一下main.py运行测试一下:

使用uv run即可

复制代码
uv run main.py

使用别人的uv项目

我们这里先删除我们自己的venv环境:

然后再重新导入这个uv项目,同步依赖,根据项目pyproject.toml文件安装所有声明的包:

复制代码
uv sync

如此,即可快速搭建与原作者一致的开发环境 。

相关推荐
ZHANG13HAO6 小时前
Python 调用 Node.js(vm2 沙箱)完美方案:胶水层实战教程
开发语言·python·node.js
asdzx676 小时前
使用 C# 将 Excel 转换成高质量 JPG
开发语言·c#·excel
瑶总迷弟6 小时前
Python入门第7章:用户输入和 while 、for循环
开发语言·python·microsoft
曲幽6 小时前
FastAPI自动生成的API文档太丑?我花了一晚上把它改成了客户愿意付费的样子
python·fastapi·web·swagger·openapi·scalar·docs
程序设计实验室7 小时前
后 Django 时代:SQLAlchemy 2.0、Tortoise 与 Piccolo 三大异步 ORM 选型指南
python
Allen_LVyingbo7 小时前
量子计算Dirac Notation基本教学—从零基础到读懂量子信息论文(上)
开发语言·数据结构·架构·健康医疗·量子计算
无巧不成书02187 小时前
Java变量初始化全攻略:2026最新规范+新手避坑实战
java·开发语言·java基础·java变量初始化·java语法规范·var关键字
爱分享的阿Q7 小时前
技术饱和度视角下的编程语言选择:一场关于供需博弈的深度思考
java·python·go
E_ICEBLUE7 小时前
Python 办公自动化:快速将 HTML 转换为 PDF 格式
python·pdf·html
Highcharts.js7 小时前
企业级可视化生态系统|关于Highcharts集成的前端框架、后端编程语言与生态
开发语言·javascript·python·前端框架·编辑器·编程语言·highcharts