一文详解如何使用uv创建并管理一个新的空白的python项目

 更新时间:2026年03月10日 09:24:20   作者:溪海莘  
这篇文章主要为大家详细介绍了如何使用uv创建并管理一个新的空白的python项目,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

一、安装 uv

# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# Windows (PowerShell)
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"

# 或使用 pip
pip install uv

二、本地项目使用 uv 进行管理

2.1创建新项目

# 创建项目目录
mkdir myproject
cd myproject

# 初始化项目(创建虚拟环境、pyproject.toml等)
uv init

或者使用一步到位的命令:

uv init myproject --python 3.11  # 指定Python版本和生成项目名称`myproject`
# 如果想要将当前目录作为项目,那么请使用:
uv init --python 3.12
cd myproject

2.2项目结构

初始化后会生成:

myproject/
├── pyproject.toml    # 项目配置和依赖
├── README.md         # 项目说明
├── .gitignore        # Git忽略文件
└── src/
    └── myproject/    # 包源代码
        └── __init__.py

2. 3管理依赖

# 添加依赖
uv add requests pandas numpy

# 添加开发依赖
uv add --dev pytest black mypy

# 从requirements.txt安装
uv pip compile requirements.txt -o pyproject.toml

# 安装所有依赖
uv sync

2.4运行和管理

# 运行Python脚本
uv run python script.py

# 启动虚拟环境shell
uv shell

# 运行测试
uv run pytest

# 查看依赖树
uv tree

2.5常用工作流示例

示例pyproject.toml:

[project]
name = "myproject"
version = "0.1.0"
description = "My awesome project"
dependencies = [
    "requests>=2.28.0",
    "pandas>=2.0.0",
]

[project.optional-dependencies]
dev = ["pytest>=7.0.0", "black>=23.0.0"]

[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"

常用命令总结:

# 创建项目
uv init <project-name>

# 添加/移除依赖
uv add <package>
uv remove <package>

# 更新所有依赖
uv sync --upgrade

# 冻结依赖版本
uv lock

# 清理缓存
uv cache clean

三、与现有项目集成

# 在现有项目中初始化uv
cd existing-project
uv init --force  # 保留现有pyproject.toml

# 从现有环境迁移
uv pip freeze > requirements.txt
uv add -r requirements.txt

uv 的优势在于速度快、集成好,同时支持依赖管理和虚拟环境管理。使用 uv 后,通常不再需要单独安装 pipvirtualenvpip-tools 等工具。

四、当你拿到一个使用 uv 管理的项目

只需要三步就能够快速配置:1. 创建虚拟环境 2. 激活虚拟环境 3. 同步项目的依赖

4.1 先安装 uv(如果还没装)

# Windows(PowerShell)
irm https://astral.sh/uv/install.ps1 | iex

# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

4.2 进入项目根目录

cd 你的项目文件夹

4.3 创建并激活虚拟环境(uv 风格)

# 创建虚拟环境(自动用项目 Python 版本)
uv venv
# 你可以指定本地 python 路径
uv venv --python "your python path."
# 激活
# Windows
.venv\Scripts\activate
# macOS/Linux
source .venv/bin/activate

4.4 安装所有依赖(最关键)

uv sync

这会根据:

  • pyproject.toml
  • uv.lock

精确安装和原项目一模一样的依赖版本

4.5. 运行项目

按项目原本的启动方式运行即可,例如:

uv run main.py
uv run fastapi dev main.py

最常用的 uv 命令(记这 5 个就够)

  • uv add 包名:安装包
  • uv remove 包名:卸载包
  • uv sync:同步依赖
  • uv run 命令:在虚拟环境里运行
  • uv pip list:看已安装包

到此这篇关于一文详解如何使用uv创建并管理一个新的空白的python项目的文章就介绍到这了,更多相关uv创建并管理python项目内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python 解析库json及jsonpath pickle的实现

    Python 解析库json及jsonpath pickle的实现

    这篇文章主要介绍了Python 解析库json及jsonpath pickle的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Python使用pyperclip库操作剪切板

    Python使用pyperclip库操作剪切板

    本文将介绍如何使用pyperclip库来进行剪切板操作,包括复制、粘贴文本和图片,以及清空剪切板内容等功能,具有一定的参考价值,感兴趣的 可以了解一下
    2024-03-03
  • python错误调试及单元文档测试过程解析

    python错误调试及单元文档测试过程解析

    这篇文章主要介绍了python错误调试及单元文档测试过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • opencv 实现特定颜色线条提取与定位操作

    opencv 实现特定颜色线条提取与定位操作

    这篇文章主要介绍了opencv 实现特定颜色线条提取与定位操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-06-06
  • anaconda的安装和配置环境及导入pycharm的方法

    anaconda的安装和配置环境及导入pycharm的方法

    这篇文章主要介绍了anaconda的安装和配置环境及导入pycharm的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • python装饰器底层原理详解

    python装饰器底层原理详解

    这篇文章主要介绍了python装饰器底层原理讲解,被装饰对象加上装饰器,被装饰对象获得了更强大的功能,更多相关内容,需要的朋友可以参考一下
    2022-07-07
  • python中的selenium入门超详细教程

    python中的selenium入门超详细教程

    这篇文章主要介绍了python中的selenium入门超详细教程,本文是在python环境下使用selenium,使用浏览器是Chrome,系统是win10系统,需要的朋友可以参考下
    2023-11-11
  • 在Python中移动目录结构的方法

    在Python中移动目录结构的方法

    这篇文章主要介绍了在Python中移动目录结构的方法,需要的朋友可以参考下
    2016-01-01
  • python基础入门之字典和集合

    python基础入门之字典和集合

    Python中的字典和集合是非常相似的数据类型,字典是无序的键值对。集合中的数据是不重复的,并且不能通过索引去修改集合中的值,我们可以往集合中新增或者修改数据。集合是无序的,并且支持数学中的集合运算,例如并集和交集等。
    2021-06-06
  • Python实现分数序列求和

    Python实现分数序列求和

    今天小编就为大家分享一篇Python实现分数序列求和,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02

最新评论