跳转至

管理依赖

依赖字段

项目的依赖在几个字段中定义:

Note

即使项目不打算发布,也可以使用 project.dependenciesproject.optional-dependencies 字段。dependency-groups 是一个最近标准化的功能,可能尚未被所有工具支持。

uv 支持使用 uv adduv remove 修改项目的依赖项,但也可以通过直接编辑 pyproject.toml 来更新依赖项元数据。

添加依赖

要添加依赖项:

$ uv add httpx

将在 project.dependencies 字段中添加一个条目:

pyproject.toml
[project]
name = "example"
version = "0.1.0"
dependencies = ["httpx>=0.27.2"]

可以使用 --dev--group--optional 标志将依赖项添加到备用字段。

依赖项将包含一个约束,例如 >=0.27.2,用于包的最新兼容版本。可以使用 --bounds 调整绑定的类型,或者直接提供约束:

$ uv add "httpx>=0.20"

当从包注册表以外的源添加依赖项时,uv 将在源字段中添加一个条目。例如,从 GitHub 添加 httpx 时:

$ uv add "httpx @ git+https://github.com/encode/httpx"

pyproject.toml 将包含一个 Git 源条目

pyproject.toml
[project]
name = "example"
version = "0.1.0"
dependencies = [
    "httpx",
]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx" }

如果无法使用依赖项,uv 将显示错误:

$ uv add "httpx>9999"
  × No solution found when resolving dependencies:
  ╰─▶ Because only httpx<=1.0.0b0 is available and your project depends on httpx>9999,
      we can conclude that your project's requirements are unsatisfiable.

导入依赖

requirements.txt 文件中声明的依赖项可以使用 -r 选项添加到项目中:

uv add -r requirements.txt

删除依赖

要删除依赖项:

$ uv remove httpx

可以使用 --dev--group--optional 标志从特定表中删除依赖项。

如果为已删除的依赖项定义了,并且没有其他对该依赖项的引用,则该源也将被删除。

更改依赖

要更改现有依赖项,例如,为 httpx 使用不同的约束:

$ uv add "httpx>0.1.0"

Note

在此示例中,我们正在更改 pyproject.toml 中依赖项的约束。只有在满足新约束所必需时,依赖项的锁定版本才会更改。要强制包版本更新到约束内的最新版本,请使用 --upgrade-package <name>,例如:

$ uv add "httpx>0.1.0" --upgrade-package httpx

有关升级包的更多详细信息,请参阅锁定文件文档。

请求不同的依赖源将更新 tool.uv.sources 表,例如,在开发期间使用本地路径中的 httpx

$ uv add "httpx @ ../httpx"

特定于平台的依赖项

为确保依赖项仅安装在特定平台或特定 Python 版本上,请使用环境标记

例如,要在 Linux 上安装 jax,但不在 Windows 或 macOS 上安装:

$ uv add "jax; sys_platform == 'linux'"

生成的 pyproject.toml 将在依赖项定义中包含环境标记:

pyproject.toml
[project]
name = "project"
version = "0.1.0"
requires-python = ">=3.11"
dependencies = ["jax; sys_platform == 'linux'"]

同样,要在 Python 3.11 及更高版本上包含 numpy

$ uv add "numpy; python_version >= '3.11'"

有关可用标记和运算符的完整列表,请参阅 Python 的环境标记文档。

Tip

依赖源也可以按平台更改

项目依赖

project.dependencies 表表示上传到 PyPI 或构建 wheel 时使用的依赖项。单个依赖项使用依赖说明符语法指定,该表遵循 PEP 621 标准。

project.dependencies 定义了项目所需的包列表,以及安装它们时应使用的版本约束。每个条目都包含一个依赖项名称和版本。一个条目可以包含用于特定于平台的包的 extras 或环境标记。例如:

pyproject.toml
[project]
name = "albatross"
version = "0.1.0"
dependencies = [
  # Any version in this range
  "tqdm >=4.66.2,<5",
  # Exactly this version of torch
  "torch ==2.2.2",
  # Install transformers with the torch extra
  "transformers[torch] >=4.39.3,<5",
  # Only install this package on older python versions
  # See "Environment Markers" for more information
  "importlib_metadata >=7.1.0,<8; python_version < '3.10'",
  "mollymawk ==0.1.0"
]

依赖源

tool.uv.sources 表使用在开发期间使用的备用依赖源扩展了标准依赖表。

依赖源添加了对 project.dependencies 标准不支持的常见模式的支持,例如可编辑安装和相对路径。例如,要从相对于项目根目录的目录安装 foo

pyproject.toml
[project]
name = "example"
version = "0.1.0"
dependencies = ["foo"]

[tool.uv.sources]
foo = { path = "./packages/foo" }

uv 支持以下依赖源:

  • 索引:从特定包索引解析的包。
  • Git:一个 Git 存储库。
  • URL:一个远程 wheel 或源分发。
  • 路径:一个本地 wheel、源分发或项目目录。
  • 工作区:当前工作区的成员。

Important

源仅受 uv 尊重。如果使用其他工具,则仅使用标准项目表中的定义。如果在开发中使用其他工具,则需要在其他工具的格式中重新指定源表中提供的任何元数据。

索引

要从特定索引添加 Python 包,请使用 --index 选项:

$ uv add torch --index pytorch=https://download.pytorch.org/whl/cpu

uv 会将索引存储在 [[tool.uv.index]] 中,并添加一个 [tool.uv.sources] 条目:

pyproject.toml
[project]
dependencies = ["torch"]

[tool.uv.sources]
torch = { index = "pytorch" }

[[tool.uv.index]]
name = "pytorch"
url = "https://download.pytorch.org/whl/cpu"

Tip

由于 PyTorch 索引的特殊性,上述示例仅适用于 x86-64 Linux。有关设置 PyTorch 的更多信息,请参阅 PyTorch 指南

使用 index 源会将包 固定 到给定的索引——它不会从其他索引下载。

定义索引时,可以包含一个 explicit 标志,以指示该索引应 用于在 tool.uv.sources 中明确指定它的包。如果未设置 explicit,则如果其他地方找不到,其他包可能会从该索引解析。

pyproject.toml
[[tool.uv.index]]
name = "pytorch"
url = "https://download.pytorch.org/whl/cpu"
explicit = true

Git

要添加 Git 依赖源,请在与 Git 兼容的 URL 前加上 git+

例如:

$ # Install over HTTP(S).
$ uv add git+https://github.com/encode/httpx

$ # Install over SSH.
$ uv add git+ssh://git@github.com/encode/httpx
pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx" }

可以请求特定的 Git 引用,例如标签:

$ uv add git+https://github.com/encode/httpx --tag 0.27.0
pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx", tag = "0.27.0" }

或者,一个分支:

$ uv add git+https://github.com/encode/httpx --branch main
pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx", branch = "main" }

或者,一个修订(提交):

$ uv add git+https://github.com/encode/httpx --rev 326b9431c761e1ef1e00b9f760d1f654c8db48c6
pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx", rev = "326b9431c761e1ef1e00b9f760d1f654c8db48c6" }

如果包不在存储库根目录中,可以指定一个 subdirectory

$ uv add git+https://github.com/langchain-ai/langchain#subdirectory=libs/langchain
pyproject.toml
[project]
dependencies = ["langchain"]

[tool.uv.sources]
langchain = { git = "https://github.com/langchain-ai/langchain", subdirectory = "libs/langchain" }

URL

要添加 URL 源,请提供一个指向 wheel(以 .whl 结尾)或源分发(通常以 .tar.gz.zip 结尾;有关所有支持的格式,请参阅此处)的 https:// URL。

例如:

$ uv add "https://files.pythonhosted.org/packages/5c/2d/3da5bdf4408b8b2800061c339f240c1802f2e82d55e50bd39c5a881f47f0/httpx-0.27.0.tar.gz"

将导致 pyproject.toml 如下:

pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { url = "https://files.pythonhosted.org/packages/5c/2d/3da5bdf4408b8b2800061c339f240c1802f2e82d55e50bd39c5a881f47f0/httpx-0.27.0.tar.gz" }

URL 依赖项也可以使用 { url = <url> } 语法在 pyproject.toml 中手动添加或编辑。如果源分发不在存档根目录中,可以指定一个 subdirectory

路径

要添加路径源,请提供 wheel(以 .whl 结尾)、源分发(通常以 .tar.gz.zip 结尾;有关所有支持的格式,请参阅此处)或包含 pyproject.toml 的目录的路径。

例如:

$ uv add /example/foo-0.1.0-py3-none-any.whl

将导致 pyproject.toml 如下:

pyproject.toml
[project]
dependencies = ["foo"]

[tool.uv.sources]
foo = { path = "/example/foo-0.1.0-py3-none-any.whl" }

路径也可以是相对路径:

$ uv add ./foo-0.1.0-py3-none-any.whl

或者,项目目录的路径:

$ uv add ~/projects/bar/

Important

默认情况下,路径依赖项不使用可编辑安装。可以为项目目录请求可编辑安装:

$ uv add --editable ../projects/bar/

这将导致 pyproject.toml 如下:

pyproject.toml
[project]
dependencies = ["bar"]

[tool.uv.sources]
bar = { path = "../projects/bar", editable = true }

同样,如果一个项目被标记为非包,但您希望将其作为包安装在环境中,请在源上设置 package = true

pyproject.toml
[project]
dependencies = ["bar"]

[tool.uv.sources]
bar = { path = "../projects/bar", package = true }

对于同一存储库中的多个包,工作区 可能更适合。

工作区成员

要声明对工作区成员的依赖,请使用 { workspace = true } 添加成员名称。必须明确说明所有工作区成员。工作区成员始终是可编辑的。有关工作区的更多详细信息,请参阅工作区文档。

pyproject.toml
[project]
dependencies = ["foo==0.1.0"]

[tool.uv.sources]
foo = { workspace = true }

[tool.uv.workspace]
members = [
  "packages/foo"
]

特定于平台的源

您可以通过为源提供与依赖说明符兼容的环境标记,将源限制在给定的平台或 Python 版本。

例如,要从 GitHub 拉取 httpx,但仅在 macOS 上,请使用以下内容:

pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = { git = "https://github.com/encode/httpx", tag = "0.27.2", marker = "sys_platform == 'darwin'" }

通过在源上指定标记,uv 仍将在所有平台上包含 httpx,但将在 macOS 上从 GitHub 下载源,并在所有其他平台上回退到 PyPI。

多个源

您可以通过提供源列表为单个依赖项指定多个源,并使用与 PEP 508 兼容的环境标记来消除歧义。

例如,要在 macOS 与 Linux 上拉入不同的 httpx 标签:

pyproject.toml
[project]
dependencies = ["httpx"]

[tool.uv.sources]
httpx = [
  { git = "https://github.com/encode/httpx", tag = "0.27.2", marker = "sys_platform == 'darwin'" },
  { git = "https://github.com/encode/httpx", tag = "0.24.1", marker = "sys_platform == 'linux'" },
]

此策略扩展到根据环境标记使用不同的索引。例如,根据平台从不同的 PyTorch 索引安装 torch

pyproject.toml
[project]
dependencies = ["torch"]

[tool.uv.sources]
torch = [
  { index = "torch-cpu", marker = "platform_system == 'Darwin'"},
  { index = "torch-gpu", marker = "platform_system == 'Linux'"},
]

[[tool.uv.index]]
name = "torch-cpu"
url = "https://download.pytorch.org/whl/cpu"
explicit = true

[[tool.uv.index]]
name = "torch-gpu"
url = "https://download.pytorch.org/whl/cu124"
explicit = true

禁用源

要指示 uv 忽略 tool.uv.sources 表(例如,模拟使用包的已发布元数据进行解析),请使用 --no-sources 标志:

$ uv lock --no-sources

使用 --no-sources 还会阻止 uv 发现任何可以满足给定依赖项的工作区成员

可选依赖

作为库发布的项目通常会将某些功能设为可选,以减少默认依赖树。例如,Pandas 有一个 excel extra 和一个 plot extra,以避免安装 Excel 解析器和 matplotlib,除非有人明确要求它们。Extras 使用 package[<extra>] 语法请求,例如 pandas[plot, excel]

可选依赖项在 [project.optional-dependencies] 中指定,这是一个 TOML 表,它将 extra 名称映射到其依赖项,遵循依赖说明符语法。

可选依赖项可以像普通依赖项一样在 tool.uv.sources 中有条目。

pyproject.toml
[project]
name = "pandas"
version = "1.0.0"

[project.optional-dependencies]
plot = [
  "matplotlib>=3.6.3"
]
excel = [
  "odfpy>=1.4.1",
  "openpyxl>=3.1.0",
  "python-calamine>=0.1.7",
  "pyxlsb>=1.0.10",
  "xlrd>=2.0.1",
  "xlsxwriter>=3.0.5"
]

要添加可选依赖项,请使用 --optional <extra> 选项:

$ uv add httpx --optional network

Note

如果您的可选依赖项相互冲突,解析将失败,除非您明确将它们声明为冲突

源也可以声明为仅适用于特定的可选依赖项。例如,根据可选的 cpugpu extra 从不同的 PyTorch 索引中拉取 torch

pyproject.toml
[project]
dependencies = []

[project.optional-dependencies]
cpu = [
  "torch",
]
gpu = [
  "torch",
]

[tool.uv.sources]
torch = [
  { index = "torch-cpu", extra = "cpu" },
  { index = "torch-gpu", extra = "gpu" },
]

[[tool.uv.index]]
name = "torch-cpu"
url = "https://download.pytorch.org/whl/cpu"

[[tool.uv.index]]
name = "torch-gpu"
url = "https://download.pytorch.org/whl/cu124"

开发依赖

与可选依赖项不同,开发依赖项是仅限本地的,在发布到 PyPI 或其他索引时,不会包含在项目需求中。因此,开发依赖项不包含在 [project] 表中。

开发依赖项可以像普通依赖项一样在 tool.uv.sources 中有条目。

要添加开发依赖项,请使用 --dev 标志:

$ uv add --dev pytest

uv 使用 [dependency-groups] 表(在 PEP 735 中定义)来声明开发依赖项。上述命令将创建一个 dev 组:

pyproject.toml
[dependency-groups]
dev = [
  "pytest >=8.1.1,<9"
]

dev 组是特殊情况;有 --dev--only-dev--no-dev 标志来切换其依赖项的包含或排除。请改用 --no-default-groups 来禁用所有默认组。此外,dev默认同步

依赖组

开发依赖项可以使用 --group 标志分为多个组。

例如,要在 lint 组中添加开发依赖项:

$ uv add --group lint ruff

这将导致以下 [dependency-groups] 定义:

pyproject.toml
[dependency-groups]
dev = [
  "pytest"
]
lint = [
  "ruff"
]

定义组后,可以使用 --all-groups--no-default-groups--group--only-group--no-group 选项来包含或排除其依赖项。

Tip

--dev--only-dev--no-dev 标志分别等效于 --group dev--only-group dev--no-group dev

uv 要求所有依赖组彼此兼容,并在创建锁文件时一起解析所有组。

如果一个组中声明的依赖项与另一个组中的依赖项不兼容,uv 将无法解析项目的需求并出现错误。

Note

如果您的依赖组相互冲突,解析将失败,除非您明确将它们声明为冲突

默认组

默认情况下,uv 在环境中包含 dev 依赖组(例如,在 uv runuv sync 期间)。可以使用 tool.uv.default-groups 设置更改要包含的默认组。

pyproject.toml
[tool.uv]
default-groups = ["dev", "foo"]

要默认启用所有依赖组,请使用 "all" 而不是列出组名:

pyproject.toml
[tool.uv]
default-groups = "all"

Tip

要在 uv runuv sync 期间禁用此行为,请使用 --no-default-groups。要排除特定的默认组,请使用 --no-group <name>

旧版 dev-dependencies

[dependency-groups] 标准化之前,uv 使用 tool.uv.dev-dependencies 字段来指定开发依赖项,例如:

pyproject.toml
[tool.uv]
dev-dependencies = [
  "pytest"
]

此部分中声明的依赖项将与 dependency-groups.dev 中的内容合并。最终,dev-dependencies 字段将被弃用和删除。

Note

如果存在 tool.uv.dev-dependencies 字段,uv add --dev 将使用现有部分,而不是添加新的 dependency-groups.dev 部分。

构建依赖

如果项目结构为 Python 包,它可能会声明构建项目所需但运行项目不需要的依赖项。这些依赖项在 [build-system] 表的 build-system.requires 下指定,遵循 PEP 518

例如,如果项目使用 setuptools 作为其构建后端,则应将 setuptools 声明为构建依赖项:

pyproject.toml
[project]
name = "pandas"
version = "0.1.0"

[build-system]
requires = ["setuptools>=42"]
build-backend = "setuptools.build_meta"

默认情况下,uv 在解析构建依赖项时会尊重 tool.uv.sources。例如,要使用本地版本的 setuptools 进行构建,请将源添加到 tool.uv.sources

pyproject.toml
[project]
name = "pandas"
version = "0.1.0"

[build-system]
requires = ["setuptools>=42"]
build-backend = "setuptools.build_meta"

[tool.uv.sources]
setuptools = { path = "./packages/setuptools" }

发布包时,我们建议运行 uv build --no-sources 以确保在禁用 tool.uv.sources 时包能正确构建,就像使用其他构建工具(如 pypa/build)时一样。

可编辑依赖

使用 Python 包对目录进行常规安装时,首先会构建一个 wheel,然后将该 wheel 安装到您的虚拟环境中,并复制所有源文件。当编辑包源文件时,虚拟环境将包含过时的版本。

可编辑安装通过在虚拟环境中添加指向项目的链接(一个 .pth 文件)来解决此问题,该链接指示解释器直接包含源文件。

可编辑安装有一些限制(主要是:构建后端需要支持它们,并且本机模块在导入前不会重新编译),但它们对于开发很有用,因为虚拟环境将始终使用包的最新更改。

uv 默认对工作区包使用可编辑安装。

要添加可编辑依赖项,请使用 --editable 标志:

$ uv add --editable ./path/foo

或者,要在工作区中选择不使用可编辑依赖项:

$ uv add --no-editable ./path/foo

依赖说明符 (PEP 508)

uv 使用依赖说明符,以前称为 PEP 508。依赖说明符按顺序由以下部分组成:

  • 依赖项名称
  • 您想要的 extras(可选)
  • 版本说明符
  • 环境标记(可选)

版本说明符用逗号分隔并加在一起,例如,foo >=1.2.3,<2,!=1.4.0 被解释为“foo 的版本至少为 1.2.3,但小于 2,且不为 1.4.0”。

如果需要,说明符会用尾随零填充,因此 foo ==2 也匹配 foo 2.0.0。

星号可用于最后一位数字与等号一起使用,例如,foo ==2.1.* 将接受 2.1 系列的任何版本。同样,~= 匹配最后一位数字等于或更高的情况,例如,foo ~=1.2 等于 foo >=1.2,<2foo ~=1.2.3 等于 foo >=1.2.3,<1.3

Extras 在名称和版本之间的方括号中用逗号分隔,例如 pandas[excel,plot] ==2.2。extra 名称之间的空格将被忽略。

某些依赖项仅在特定环境中需要,例如特定的 Python 版本或操作系统。例如,要为 importlib.metadata 模块安装 importlib-metadata 向后移植,请使用 importlib-metadata >=7.1.0,<8; python_version < '3.10'。要在 Windows 上安装 colorama(但在其他平台上省略它),请使用 colorama >=0.4.6,<5; platform_system == "Windows"

标记与 andor 和括号组合使用,例如 aiohttp >=3.7.4,<4; (sys_platform != 'win32' or implementation_name != 'pypy') and python_version >= '3.10'。请注意,标记内的版本必须加引号,而标记 的版本 不能 加引号。