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

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

相关推荐
Msshu1235 分钟前
消费类,小家电产品如何做Type-C PD快充快速充电
python·单片机·嵌入式硬件·物联网·beautifulsoup·fastapi·tornado
emplace_back19 分钟前
C# 项目
开发语言·c#
lkx0978822 分钟前
第八天的尝试
python
(・Д・)ノ24 分钟前
python打卡day33
开发语言·python
小革36037 分钟前
JAVA批量发送邮件(含excel内容)
开发语言·python·excel
阿梦Anmory38 分钟前
[解决conda创建新的虚拟环境没用python的问题]
开发语言·python·conda
L_cl39 分钟前
【NLP 77、Python环境管理工具之conda】
python·自然语言处理·conda
心扬1 小时前
python容器
开发语言·python
我漫长的孤独流浪2 小时前
STL中的Vector(顺序表)
开发语言·c++·算法
一刀到底2112 小时前
java 在用redis 的时候,如何合理的处理分页问题? redis应当如何存储性能最佳
java·开发语言·redis