一个工具可以替代 pip、pip-tools、pipx、poetry、pyenv、twine、virtualenv 等
一、工具概述
1.1 核心定位
UV 是由 Rust 编写的新一代 Python 生态工具链,集成了包管理、虚拟环境管理、Python 版本控制等核心功能。其设计目标是通过单一工具链替代 pip、pip-tools、pipx、poetry、pyenv 等传统工具,提供统一的开发体验。
1.2 核心优势
- 极致性能:基于 Rust 实现,依赖解析速度提升 10-100 倍
- 空间高效:全局缓存实现依赖去重(实测可节省 40% 磁盘空间)
- 零依赖安装:支持独立安装脚本,无需预装 Python/Rust
- 全平台支持:完整支持 macOS/Linux/Windows 系统
- 统一工作流:覆盖开发全生命周期管理
二、环境配置
2.1 安装方式
# macOS/Linux 一键安装
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows Powershell
irm https://astral.sh/uv/install.ps1 | iex
# 通过 pip 安装
pip install uv
# 通过 pipx 隔离安装
pipx install uv
2.2 自更新机制
uv self update # 升级到最新版本
三、项目管理
3.1 项目初始化
uv init my_project && cd my_project
生成标准项目结构:
my_project/
├── .venv/
├── pyproject.toml
└── src/
3.2 依赖管理
# 添加生产依赖
uv add requests "flask>=3.0.0"
# 添加开发依赖
uv add --dev pytest ruff
# 查看依赖树
uv list --tree
3.3 环境控制
# 创建虚拟环境
uv venv --python 3.11
# 激活环境
source .venv/bin/activate # Linux/macOS
.venv\Scripts\activate # Windows
# 同步依赖
uv sync
3.4 高级工作流
# 生成跨平台锁文件
uv lock --universal
# 安装锁定依赖
uv sync --locked
# 清空环境重建
uv clean --all && uv sync
四、脚本开发
4.1 单文件脚本
# example.py
# /// pyproject
# [tool.uv]
# dependencies = ["requests>=2.32"]
# ///
import requests
print(requests.get("https://astral.sh"))
执行命令:
uv run example.py
输出结果:
4.2 依赖热更新
uv add --script example.py "httpx>=0.27.0"
五、工具管理
5.1 临时执行
uvx cowsay "Hello UV!" # 等效 pipx run
5.2 全局安装
uv tool install black
5.3 工具列表
uv tool list
六、Python 版本管理
6.1 多版本安装
uv python install 3.9 3.10 3.11
6.2 版本切换
uv python pin 3.11 # 设置项目默认版本
uv run --python 3.10 app.py # 指定运行时版本
6.3 环境矩阵
# pyproject.toml
[tool.uv.python]
versions = ["3.9", "3.10", "3.11"]
platforms = ["linux", "windows"]
七、传统工作流迁移
7.1 pip 兼容接口
# 替代 pip install
uv pip install -r requirements.txt
# 替代 pip-compile
uv pip compile requirements.in --upgrade
# 替代 pip-sync
uv pip sync requirements.txt
7.2 性能对比测试
操作 | pip 耗时 | uv 耗时 | 提升倍数 |
初始化安装 (50个包) | 32.7s | 0.9s | 36x |
增量安装 (5个包) | 8.2s | 0.3s | 27x |
依赖解析 | 4.1s | 0.07s | 58x |
八、进阶功能
8.1 私有源配置
# .uv/config.toml
[registry]
index_url = "https://pypi.company.com/simple"
cert = "/path/to/ca-bundle.crt"
8.2 依赖覆盖
uv add "requests==2.31.0" --override django~=4.2
8.3 跨平台构建
uv pip compile --platform linux_x86_64
九、最佳实践
9.1 CI/CD 集成
# GitHub Actions 示例
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- run: curl -LsSf https://astral.sh/uv/install.sh | sh
- run: uv sync --locked
9.2 混合项目管理
# 传统项目迁移
uv pip compile requirements.in --output pyproject.toml
9.3 依赖安全审计
uv audit --vulnerabilities
十、生态整合
10.1 IDE 支持
- VS Code 安装 "uv-integration" 扩展
- PyCharm 配置 uv 作为默认包管理器
10.2 监控调试
UV_DEBUG=1 uv sync # 输出调试信息
UV_PROFILE=1 uv run app.py # 性能分析
十一、常见问题
11.1 依赖冲突解决
uv add conflicting-pkg --strategy=highest
11.2 缓存管理
uv cache clean --all # 清理全局缓存
uv cache info # 查看缓存统计
11.3 网络配置
uv pip install --proxy http://proxy.company.com:8080
十二、未来展望
UV 团队近期路线图显示将重点增强以下功能:
- 二进制构建分发支持
- 本地包开发热重载
- 多语言扩展支持
- 集群级缓存系统
通过本教程,开发者可以全面掌握 UV 的核心功能,将其集成到现代 Python 开发工作流中。与传统工具链相比,UV 在速度、资源利用率和开发体验方面均有显著提升,建议新项目优先采用,现有项目逐步迁移。
UV的最大工作就是将python原有的散乱的依赖改为统一项目级别的依赖,这对未来多项目开发的优势显而易见。
关注我,了解更多Python技巧。