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

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

相关推荐
梦境虽美,却不长2 分钟前
C语言 学习 文件操作(开关,读写,定位,大小)操作 2025年6月8日12:19:24
c语言·开发语言·学习
nvvas8 分钟前
Python Selenium固定端口测试chrome浏览器绕过登录验证
chrome·python·selenium
Charlotte_jc10 分钟前
完美解决openpyxl保存Excel丢失图像/形状资源的技术方案
开发语言·python·excel·openpyxl
西北大程序猿30 分钟前
服务器代码知识点补充
服务器·开发语言·网络·c++·网络协议
西柚小萌新2 小时前
【大模型:知识库管理】--Dify接入RAGFlow 知识库
python
新知图书2 小时前
R语言ICU患者死亡率预测实战
开发语言·r语言
博士僧小星2 小时前
在线机考|2025年华为暑期实习&春招&秋招编程题(最新)——第2题_网络整改
python·华为·在线编程·机考·秋招笔试
博士僧小星2 小时前
在线机考|2025年华为暑期实习&春招&秋招编程题(最新)——第1题_物流运输
python·华为·机考·春招·秋招笔试·在线笔试
wennieFan3 小时前
python基础面试练习题
开发语言·python
电院工程师3 小时前
轻量级密码算法CHAM的python实现
python·嵌入式硬件·算法·安全·密码学