【Python】使用uv管理python虚拟环境

【Python】使用uv管理python虚拟环境

本文介绍了python虚拟环境管理工具uv,包括uv的作用、uv的常用命令等等。

参考:UV - 管理Python 版本、环境、第三方包

1. 介绍uv

官网:https://docs.astral.sh/uv/

uv是一个python虚拟环境管理工具,可以用来替代pip、pyenv、virtualenv等等工具。根据官网的介绍,使用uv来管理虚拟环境,相比于pip能得到至少10倍以上的性能提升。

uv工具有如下功能:

  • 管理python版本;
  • 管理第三方库(Python packages)的版本;
  • 拥有全局的第三方库的缓存,能减少磁盘空间占用;
  • 安装uv不需要python环境,可以通过curl或pip安装;
  • 多平台支持:macOS、Linux、Windows;

试用过后,感觉uv还是很不错的,于是编写本文,推荐给大家。

image.png

2. 安装uv

文档:https://docs.astral.sh/uv/getting-started/installation/

在linux和mac上的安装直接使用curl或者wget命令即可

curl -LsSf https://astral.sh/uv/install.sh | sh # 或者wget(效果一样) wget -qO- https://astral.sh/uv/install.sh | sh 

在windows上的安装命令如下

powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex" 

在mac上安装之后,终端输出如下

❯ curl -LsSf https://astral.sh/uv/install.sh | sh downloading uv 0.6.14 aarch64-apple-darwin no checksums to verify installing to /Users/mothra/.local/bin uv uvx everything's installed! To add $HOME/.local/bin to your PATH, either restart your shell or run: source $HOME/.local/bin/env (sh, bash, zsh) source $HOME/.local/bin/env.fish (fish) 

这里给出了提示,必须把$HOME/.local/bin这个路径加到环境变量PATH里面才可以正常使用uv工具。设置之后,使用uv --version命令确认安装成功。

❯ uv --version uv 0.6.14 (a4cec56dc 2025-04-09) 

2.1. 卸载uv

卸载uv之前,先执行如下命令删除所有本地缓存文件

uv cache clean rm -r "$(uv python dir)" rm -r "$(uv tool dir)" 

然后再删除uv的二进制文件

# mac/linux rm ~/.local/bin/uv ~/.local/bin/uvx # windows rm $HOME.local\bin\uv.exe rm $HOME.local\bin\uvx.exe 

3. 基本使用

3.1. 管理python版本

使用如下命令,显示出当前环境中所有可用的python版本(包括已经安装的和可以安装的)

uv python list 

在我的电脑上,输出如下,我的电脑上安装了python 3.9.6(xcode开发者工具安装的)、python 3.10.11、python 3.13.1版本,这几个版本都可以用uv来调用。

❯ uv python list cpython-3.14.0a6-macos-aarch64-none <download available> cpython-3.14.0a6+freethreaded-macos-aarch64-none <download available> cpython-3.13.3-macos-aarch64-none <download available> cpython-3.13.3+freethreaded-macos-aarch64-none <download available> cpython-3.13.1-macos-aarch64-none /opt/homebrew/bin/python3.13 -> ../Cellar/[email protected]/3.13.1/bin/python3.13 cpython-3.13.1-macos-aarch64-none /opt/homebrew/bin/python3 -> ../Cellar/[email protected]/3.13.1/bin/python3 cpython-3.13.0a3-macos-aarch64-none /usr/local/bin/python3.13 -> ../../../Library/Frameworks/Python.framework/Versions/3.13/bin/python3.13 cpython-3.12.10-macos-aarch64-none <download available> cpython-3.11.12-macos-aarch64-none <download available> cpython-3.10.17-macos-aarch64-none <download available> cpython-3.10.11-macos-aarch64-none /usr/local/bin/python3.10 -> ../../../Library/Frameworks/Python.framework/Versions/3.10/bin/python3.10 cpython-3.10.11-macos-aarch64-none /usr/local/bin/python3 -> ../../../Library/Frameworks/Python.framework/Versions/3.10/bin/python3 cpython-3.10.11-macos-aarch64-none /Library/Frameworks/Python.framework/Versions/3.10/bin/python3.10 cpython-3.10.11-macos-aarch64-none /Library/Frameworks/Python.framework/Versions/3.10/bin/python3 -> python3.10 cpython-3.9.22-macos-aarch64-none <download available> cpython-3.9.6-macos-aarch64-none /usr/bin/python3 cpython-3.8.20-macos-aarch64-none <download available> 

如果需要安装其他版本的python,使用如下命令

uv python install 3.12 

除了标准python之外,还可以安装其他的Python实现,比如PyPy实现的python

uv python install [email protected] 

查找某个python版本的路径

❯ uv python find 3.10 /Library/Frameworks/Python.framework/Versions/3.10/bin/python3.10 

查看已经安装的python版本

uv python list 

3.2. 选用python版本

在具体的某个项目中,进入项目目录,使用如下命令指定选用的python版本

uv python pin 版本号 

这个命令会在指定目录下创建一个.python-version文件,内容如下

❯ uv python pin 3.10 Pinned `.python-version` to `3.10` ❯ cat .python-version 3.10 

注意,这里选用的python版本只和uv管理的虚拟环境有关系,和我们全局的python、python3命令都没有关系。

3.3. 创建虚拟环境(项目)

创建项目有两种方式,第一种方式,先创建好项目目录,然后设置python版本并初始化uv虚拟环境

uv python pin 3.10 uv init # 初始化 

执行了uv init之后,会在当前目录下创建几个文件,同时也会在当前目录下执行git init创建出一个新的git仓库来

~/data/code/python/test_code ❯ uv python pin 3.13 Pinned `.python-version` to `3.13` ~/data/code/python/test_code ❯ uv init Initialized project `test-code` ~/data/code/python/test_code main ?6 ❯ ls README.md main.py pyproject.toml 

另外一个方式是在init之后添加一个项目名,会自动创建项目文件夹

uv init 项目名 

如果需要指定特定python版本,建议使用第一种方式来创建项目,否则还需要手动修改pyproject.toml配置文件里面需要的python版本。

3.4. 添加依赖

uv add 依赖项 

比如添加requests库

uv add requests 

还可以指定具体版本

uv add requests==版本号 

执行了这个命令后,会在当前目录下创建.venv虚拟环境目录(在vscode里面可以选择这个目录作为虚拟环境,否则代码解析会有问题),并添加我们要的依赖项,同时会新增一个uv.lock文件,用于存放依赖项版本相关的信息。pyproject.toml文件中的dependencies字段也会包含需要的依赖项。

~/data/code/python/test_code main ?6 ❯ uv add requests Using CPython 3.13.1 interpreter at: /opt/homebrew/opt/[email protected]/bin/python3.13 Creating virtual environment at: .venv Resolved 6 packages in 13.85s Prepared 5 packages in 5.55s Installed 5 packages in 13ms + certifi==2025.1.31 + charset-normalizer==3.4.1 + idna==3.10 + requests==2.32.3 + urllib3==2.4.0 

而且,从这个输出中也能看到,它自动使用了.python-version指定的3.13版本的python,和当前我们全局目录下的python3指向什么版本没有关系(我的全局python3指向的是3.10版本)

3.5. 运行程序

依赖添加好后,就可以使用uv来运行python程序了

uv run 程序文件名 [命令行参数] 

uv会自动按照我们的配置来运行程序,无序我们手动维护依赖项,也不需要手动去source各式各样的虚拟环境了。

3.6. uvx命令

随着uv下载的还有一个uvx命令,uvx命令本质上是uv tool run命令的别名,

uvx python main.py # 等价于 uv run main.py # 等价于 uv tool run main.py 

实际例子,如下这两个命令是等价的

❯ uvx --directory ~/data/code/python/test_code python main.py Hello from test-code! ❯ uv tool run --directory ~/data/code/python/test_code python main.py Hello from test-code! 

3.7. 小结

基本操作就是这些了,更多复杂的操作详见uv的官网。

4. 设置下载包的镜像源

参考:https://blog.ZEEKLOG.net/qq_41472205/article/details/145686414

uv下载第三方库本质上也是通过pypi源下载的,所以在国内网络环境中默认链接速度会很慢,可以在项目目录的pyproject.toml中添加如下内容来使用清华源

[[tool.uv.index]] url = "https://pypi.tuna.tsinghua.edu.cn/simple" default = true 

运行uv add命令的时候也可以指定镜像源

uv add --default-index https://pypi.tuna.tsinghua.edu.cn/simple requests 

uv也提供了全局的配置项,可以通过环境变量UV_DEFAULT_INDEX配置镜像源

exportUV_DEFAULT_INDEX=https://pypi.tuna.tsinghua.edu.cn/simple 

全局的配置项优先级低于pyproject.toml中配置的镜像源。如果pyproject.toml里面配置了镜像源,则会使用pyproject.toml的配置。

5. 大模型mcp协议和uv

最近,ai agent中mcp协议的推出,让慕雪了解到了uv工具。对于mcp而言,mcp server的开发可以使用python来编写,此时python环境的管理就非常重要了。

以常见的mcp客户端配置举例,示例配置如下,其中test.py是我们编写的一个mcp服务器。

{"mcpServers":{"工具名称":{"command":"uv","args":{"--directory","工作路径","run","test.py"}}}}

下图是mcp server和mcp client交互的简要逻辑(这只是个简要的流程)

graph TD; A[ai工具加载mcp配置] --> |启动mcp服务器|B B[mcp client] --> |链接服务器,调用工具|C[mcp server] C -->|返回工具调用结果|B 

其中第一步,ai工具加载mcp配置的时候,就需要去根据我们填写的mcpSever的配置来通过uv启动我们的服务端了,此时如果还是用python自带的venv来管理虚拟环境就不够用了,因为这里没有办法指定虚拟环境的路径,也没有人去source venv/bin/activate那个虚拟环境,所以mcp需要一个解决方案来更好的管理python的虚拟环境,此时uv就登场了。

使用了uv,直接执行uv run就可以了,uv工具自动帮我们维护了虚拟环境,并使用了指定环境来运行我们的服务端代码,一切问题都解决啦!

而且,mcp强制使用uv,也进一步规范了使用python编写mcp server的格式,再也不用担心某些开源python项目的根目录下连requirements.txt都没有的尴尬情况了。

本文首发地址:【Python】使用uv管理python虚拟环境,首发于 2025-04-14 21:29:43

点我查看更多精彩内容:慕雪的寒舍

Read more

SDWebImage 在 Flutter 中的使用:通过插件桥接

SDWebImage 在 Flutter 中的使用:通过插件桥接 关键词:SDWebImage、Flutter插件、跨平台桥接、MethodChannel、图片加载缓存 摘要:本文将带你探索如何在 Flutter 中通过插件桥接技术调用 iOS 原生的 SDWebImage 库。我们会从背景需求出发,用“跨国快递”的比喻解释桥接原理,逐步拆解核心概念,结合代码实战演示如何实现图片加载与缓存,并总结常见问题与未来优化方向。即使你是 Flutter 新手,也能轻松理解跨平台桥接的底层逻辑! 背景介绍 目的和范围 在 Flutter 开发中,图片加载是高频需求。虽然 Flutter 自带 cached_network_image 等第三方库,但在 iOS 平台上,原生的 SDWebImage 经过多年优化,在缓存策略、

By Ne0inhk
实战:手写一个通用Web层鉴权注解,解决水平权限漏洞

实战:手写一个通用Web层鉴权注解,解决水平权限漏洞

实战:手写一个通用Web层鉴权注解,解决水平权限漏洞 * 一、背景:一次渗透测试引发的改造 * 二、需求分析:如何高效修复 * 三、业务模型:用户-公司授权关系 * 四、整体架构设计 * 五、代码实现:一步一步来 * 5.1 注解定义 * 5.2 权限管理服务 * 5.3 AOP切面:核心逻辑 * 六、使用示例 * 6.1 场景1:最简单的用法 * 6.2 场景2:对象属性 * 6.3 场景3:批量操作 * 6.4 场景4:嵌套属性 * 6.5 场景5:类级别默认配置 * 七、

By Ne0inhk
Flutter 三方库 arcade 的鸿蒙化适配指南 - 实现高性能的端侧 Web 框架、支持轻量级 HTTP 路由分发与服务端逻辑集成

Flutter 三方库 arcade 的鸿蒙化适配指南 - 实现高性能的端侧 Web 框架、支持轻量级 HTTP 路由分发与服务端逻辑集成

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 arcade 的鸿蒙化适配指南 - 实现高性能的端侧 Web 框架、支持轻量级 HTTP 路由分发与服务端逻辑集成 前言 在进行 Flutter for OpenHarmony 的全栈式开发或特定的边缘计算场景,我们有时需要在鸿蒙应用内部直接启动一个功能完备但又极其轻量的单文件 Web 服务器。arcade 是一个主打微核心设计的 Dart 服务端框架。它能让你在鸿蒙真机上以最少的内存占用,快速运行起一套处理 REST 请求的逻辑中心。本文将指导大家如何在鸿蒙端利用该框架构建微服务。 一、原理解析 / 概念介绍 1.1 基础原理 arcade 采用了非阻塞式的 IO 事件循环架构。它通过直接包装 dart:io 的 HttpServer,提供了一套高度流式(

By Ne0inhk

GLM-4.6V-Flash-WEB适用于哪些类型的图像问答场景?

GLM-4.6V-Flash-WEB适用于哪些类型的图像问答场景? 在如今的智能交互时代,用户不再满足于“上传图片 → 返回标签”的简单视觉识别模式。越来越多的应用场景要求系统不仅能“看见”图像内容,还要能“理解”并“回答”复杂问题——比如学生对着课本截图提问电路原理,客服系统自动解析用户发来的产品照片,或是企业从扫描报表中提取关键数据。 正是在这样的需求推动下,多模态大模型正从实验室走向真实业务前线。而 GLM-4.6V-Flash-WEB 的出现,恰好填补了高性能与可落地之间的空白:它不像某些重型模型那样动辄需要A100集群支撑,也不像传统OCR+规则引擎那样缺乏语义推理能力。这款由智谱AI推出的轻量化视觉语言模型,专为Web服务和高并发场景设计,在毫秒级响应与较强图文理解之间找到了极佳平衡点。 从一张菜单说起:什么是真正的图像问答? 设想这样一个场景:你走进一家餐厅,拍下纸质菜单上传到某个AI助手,然后问:“最贵的菜是什么?” 如果系统只能做OCR,它会返回一串文字列表;如果只是图像分类,可能告诉你“这是一张食物相关的图”。但真正有用的回应应该是: “牛排套餐,价格为

By Ne0inhk