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

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

相关推荐
城管不管8 分钟前
SpringBoot与反射
java·开发语言·前端
十启树22 分钟前
常见开发语言在 Windows 上的默认编码格式
开发语言
eqwaak026 分钟前
科技信息差(9.22)
开发语言·python·科技·语言模型
胡耀超35 分钟前
37、RAG系统架构与实现:知识增强型AI的完整构建
开发语言·人工智能·python·深度学习·神经网络·系统架构
Q_Q19632884751 小时前
python+django/flask二手物品交易系统 二手商品发布 分类浏览 在线沟通与订单管理系统java+nodejs
java·spring boot·python·django·flask·node.js·php
小闫BI设源码1 小时前
Python Flask快速入门
开发语言·python·flask
九年义务漏网鲨鱼1 小时前
等效学习率翻倍?梯度累积三连坑:未除以 accum_steps、调度器步进错位、梯度裁剪/正则标度错误(含可复现实验与修复模板)
python·深度学习·学习
mortimer2 小时前
Python `asyncio` 在后台线程中的“死亡螺旋”:一次从入门到放弃的调试实录
python
Nue.js2 小时前
最新b站加密关键字段的逆向(视频和评论爬取)
爬虫·python·安全
王嘉俊9252 小时前
Java面试宝典:核心基础知识精讲
java·开发语言·面试·java基础·八股文