uv: 一个统一的Python包管理工具

uv是由Astral公司开发的一个极其快速的Python包管理器,完全用Rust编写。它最初在2月份发布,作为pip工作流的替代品。现在,uv已经扩展成为一个端到端的解决方案,可以管理Python项目、命令行工具、单文件脚本,甚至Python本身。可以说,uv就像是Python界的Cargo:一个快速、可靠、易用的统一接口。

主要特性

uv具有以下主要功能:

端到端项目管理:

通过uv runuv lockuv sync,uv可以基于标准元数据生成跨平台的锁文件,并从中安装依赖,类似Poetry、PDM和Rye等工具,但性能更高。

工具管理:

通过uv tool installuv tool run(别名uvx),uv可以在隔离的虚拟环境中安装命令行工具,并无需显式安装即可执行一次性命令(如uvx ruff check),类似pipx但速度更快。

Python安装:

通过uv python install,uv可以自动下载安装Python,类似pyenv但更高效。

脚本执行:

uv支持基于PEP 723的内联元数据的单文件Python脚本。只需uv run即可执行独立的Python脚本。

以上所有功能都基于uv极快的跨平台依赖解析器。下图展示了在有无缓存的情况下,uv解析Transformers项目全部可选依赖的速度:

使用示例

下面通过一些示例代码展示uv的基本用法。

安装uv:

bash 复制代码
$ curl -LsSf https://astral.sh/uv/install.sh | sh
$ pip install uv 
$ pipx install uv

管理Python项目:

初始化项目并添加fastapi依赖:

bash 复制代码
$ uv init && uv add "fastapi>=0.112"

会生成如下pyproject.toml:

toml 复制代码
[project]
name = "hello-world"  
version = "0.1.0"
readme = "README.md"
dependencies = ["fastapi>=0.112"]

然后uv会基于项目依赖创建一个锁文件,保证项目环境在不同机器上的一致性。

通过uv run可以直接在项目环境中执行命令,无需手动激活虚拟环境

管理命令行工具:

通过uv tool install可以把命令行工具(如Ruff)安装到隔离的虚拟环境中,通过uvx可以直接执行命令而无需安装:

执行单文件脚本:

考虑如下main.py,它依赖requestsrich,但没有包含任何元数据:

python 复制代码
import requests
from rich.pretty import pprint

resp = requests.get("https://peps.python.org/api/peps.json") 
data = resp.json()
pprint([(k, v["title"]) for k, v in data.items()][:10])

通过uv add可以自动将依赖声明嵌入到脚本中:

bash 复制代码
$ uv add --script main.py "requests<3" "rich"

然后通过uv run main.py即可在隔离环境中执行脚本并自动安装依赖

总结

uv是一个功能强大、简单易用的Python包管理工具,集成了端到端的解决方案。它在性能和可靠性上都有突出的优势。

无论是小型脚本还是大型项目,从初学者到专家,uv都能很好地满足Python开发的各种需求。Astral公司希望通过uv来降低Python开发的复杂度,提高生产力。

如果你在内部使用uv,并有兴趣在Python打包方面与Astral合作,欢迎联系他们,共同应对未来的挑战。

相关推荐
我不想当小卡拉米几秒前
C++:继承+菱形虚拟继承的一箭双雕
开发语言·jvm·c++
weixin_457885823 分钟前
JavaScript智能对话机器人——企业知识库自动化
开发语言·javascript·自动化
东方佑12 分钟前
利用Python自动化处理PPT样式与结构:从提取到生成
python·自动化·powerpoint
孤独得猿25 分钟前
Qt常用控件第一部分
服务器·开发语言·qt
慕斯策划一场流浪30 分钟前
fastGPT—nextjs—mongoose—团队管理之团队列表api接口实现
开发语言·前端·javascript·fastgpt env文件配置·fastgpt团队列表接口实现·fastgpt团队切换api·fastgpt团队切换逻辑
橘猫云计算机设计37 分钟前
基于springboot的考研成绩查询系统(源码+lw+部署文档+讲解),源码可白嫖!
java·spring boot·后端·python·考研·django·毕业设计
时光呢41 分钟前
JAVA常见的 JVM 参数及其典型默认值
java·开发语言·jvm
橙橙子23043 分钟前
c++柔性数组、友元、类模版
开发语言·c++·柔性数组
超级小的大杯柠檬水1 小时前
修改Anaconda中Jupyter Notebook默认工作路径的详细图文教程(Win 11)
ide·python·jupyter