Python 第三方库:uv(极速包管理器)

uv 是一个基于 Rust 编写的现代化 Python 包管理工具,旨在替代 pip、venv、pip-tools 等多个工具,提供极速依赖解析、虚拟环境自动化、锁文件管理等一站式功能。

安装方式 1:使用 pip 安装(适用于测试)

nginx 复制代码
pip install uv

注意:此方式不包含 Rust 加速,性能较低,适合测试而非生产环境。

安装方式 2:推荐方式(官方脚本)

nginx 复制代码
# Linux 或 macOScurl -Ls https://astral.sh/uv/install.sh | bash
# Windows 用户建议使用 Powershell 安装(或手动下载可执行文件)irm https://astral.sh/uv/install.ps1 | iex

提示:

在 Windows 中安装完成后,请将 uv 可执行文件路径(如 C:\Users\<用户名>\.local\bin)加入环境变量 PATH

bash 复制代码
# CMDset Path=%USERPROFILE%\.local\bin;%PATH%
# Powershell$env:Path = "%USERPROFILE%\.local\bin;$env:Path"

安装方式 3:使用 Homebrew(macOS)

bash 复制代码
brew install astral-sh/uv/uv

安装完成后,可直接输入命令验证:

bash 复制代码
uv --help

常见应用场景:

(1)快速创建 Python 虚拟环境并安装依赖。

(2)构建现代工程项目并精确锁定依赖。

(3)在 CI/CD 场景中重现相同的开发环境。

(4)使用 uv run 无需激活环境即可运行脚本。

(5)安装开发依赖(dev-dependencies)。

(6)管理项目中使用的工具链(如 ruff、black 等)。

(7)构建和发布 Python 包。

◆ ◆

核心概念

1、声明式依赖管理

使用 pyproject.toml 声明依赖。

2、锁文件机制

生成 uv.lock,完整记录依赖版本及子依赖。

3、自动虚拟环境

无需手动建 .venv,uv 自动处理。

4、隔离执行环境

运行脚本时自动启用项目虚拟环境。

5、高速依赖解析

基于 Rust 实现,比 pip 快数倍。

6、工具安装隔离

使用 uv tool 安装命令行工具而不污染全局。

◆ ◆

基本用法

1、初始化项目

cs 复制代码
uv init

生成 pyproject.toml,用于声明依赖。

2、添加依赖(自动锁定)

cs 复制代码
uv add requests

自动写入 pyproject.toml 与 uv.lock。

说明:

上述命令以添加 Request 第三方库为例。

3、同步安装依赖

bash 复制代码
uv sync

根据锁文件同步所有依赖,默认自动使用 .venv 或 .uv 目录。

4、安装开发依赖

sql 复制代码
uv add --dev pytest

5、移除依赖

cs 复制代码
uv remove requests

6、执行脚本(无需手动激活环境)

nginx 复制代码
uv run python example.py

7、全局安装依赖(不推荐)

css 复制代码
uv pip install requests --system

◆ ◆

uv 命令解释

项目与依赖管理相关

uv run

在项目环境中运行命令或脚本。

nginx 复制代码
uv run python example.py

uv init

初始化 pyproject.toml,创建项目配置。

uv add

向项目中添加依赖包并更新 lock 文件。

cs 复制代码
uv add requests

uv remove

从项目中移除指定依赖包。

cs 复制代码
uv remove requests

uv version

查看或修改项目版本号。

uv sync

安装锁定依赖到本地虚拟环境。

uv lock

仅更新 uv.lock,不安装依赖。

uv export

导出 uv.lock 为其他格式,兼容 pip。

javascript 复制代码
uv export --format=requirements.txt

uv tree

查看依赖树结构(含子依赖)。

Python 与工具链管理

uv tool

安装并运行 Python 命令行工具,工具即装即用,无需创建虚拟环境,也不会污染全局环境。

nginx 复制代码
uv tool install ruff       # 安装 ruff 工具
uv tool run ruff check .   # 执行 ruff 检查当前目录

uv python

安装指定版本 Python(需配置 Python 镜像)。

apache 复制代码
uv python install 3.13

uv pip

提供兼容 pip 命令的接口,用于包管理。

nginx 复制代码
uv pip install numpy  #使用 pip 风格命令安装包uv pip freeze    # 冻结当前环境依赖

uv venv

创建新的虚拟环境。

nginx 复制代码
uv venv myvenv

构建与发布相关

uv build

构建项目为分发包(wheel、sdist)。

uv publish

发布包到 PyPI。

其他工具

uv cache

管理 uv 的缓存。

nginx 复制代码
uv cache clean    # 查看缓存内容
uv cache clean    # 清理缓存

uv self

管理 uv 自身(如升级 uv)。

nginx 复制代码
uv self update

uv help

显示帮助文档。

bash 复制代码
uv help add

◆ ◆

补充说明

1、无需激活虚拟环境

所有命令默认识别项目路径并自动进入虚拟环境,不再需要 source venv/bin/activate 或 .venv\Scripts\activate。

2、锁文件作用

pyproject.toml 表示"我想要哪些依赖"。

uv.lock 表示"我实际使用的完整依赖"。

适用于部署与 CI 场景。

3、uv 与 pip 的区别

(1)uv 不依赖 pip,而是自带依赖解析与安装逻辑。

(2)兼容 pip 命令,用法平滑迁移。

(3)安装速度远胜 pip。

4、在 GitHub Actions 中使用 uv

bash 复制代码
- name: Install uv  run: curl -Ls https://astral.sh/uv/install.sh | bash
- name: Install dependencies  run: uv sync

5、参考链接

官方网站:https://astral.sh/blog/uv/

GitHub 项目:https://github.com/astral-sh/uv

"点赞有美意,赞赏是鼓励"

相关推荐
zone77398 小时前
001:简单 RAG 入门
后端·python·面试
F_Quant8 小时前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来9 小时前
在node项目中执行python脚本
前端·python·node.js
IVEN_9 小时前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend10 小时前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽10 小时前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_1 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮1 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling1 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python