Tools#
Tools are Python packages that provide command-line interfaces.
Note
See the tools guide for an introduction to working with the tools interface — this document discusses details of tool management.
The uv tool
interface#
uv includes a dedicated interface for interacting with tools. Tools can be invoked without
installation using uv tool run
, in which case their dependencies are installed in a temporary
virtual environment isolated from the current project.
Because it is very common to run tools without installing them, a uvx
alias is provided for
uv tool run
— the two commands are exactly equivalent. For brevity, the documentation will mostly
refer to uvx
instead of uv tool run
.
Tools can also be installed with uv tool install
, in which case their executables are
available on the PATH
— an isolated virtual environment is still used, but it is not
removed when the command completes.
Execution vs installation#
In most cases, executing a tool with uvx
is more appropriate than installing the tool. Installing
the tool is useful if you need the tool to be available to other programs on your system, e.g., if
some script you do not control requires the tool, or if you are in a Docker image and want to make
the tool available to users.
Tool environments#
When running a tool with uvx
, a virtual environment is stored in the uv cache directory and is
treated as disposable, i.e., if you run uv cache clean
the environment will be deleted. The
environment is only cached to reduce the overhead of repeated invocations. If the environment is
removed, a new one will be created automatically.
When installing a tool with uv tool install
, a virtual environment is created in the uv tools
directory. The environment will not be removed unless the tool is uninstalled. If the environment is
manually deleted, the tool will fail to run.
Tool versions#
Unless a specific version is requested, uv tool install
will install the latest available of the
requested tool. uvx
will use the latest available version of the requested tool on the first
invocation. After that, uvx
will use the cached version of the tool unless a different version is
requested, the cache is pruned, or the cache is refreshed.
For example, to run a specific version of Ruff:
$ uvx [email protected] --version
ruff 0.6.0
A subsequent invocation of uvx
will use the latest, not the cached, version.
But, if a new version of Ruff was released, it would not be used unless the cache was refreshed.
To request the latest version of Ruff and refresh the cache, use the @latest
suffix:
Once a tool is installed with uv tool install
, uvx
will use the installed version by default.
For example, after installing an older version of Ruff:
The version of ruff
and uvx ruff
is the same:
However, you can ignore the installed version by requesting the latest version explicitly, e.g.:
Or, by using the --isolated
flag, which will avoid refreshing the cache but ignore the installed
version:
uv tool install
will also respect the {package}@{version}
and {package}@latest
specifiers, as
in:
$ uv tool install ruff@latest
$ uv tool install [email protected]
Tools directory#
By default, the uv tools directory is named tools
and is in the uv application state directory,
e.g., ~/.local/share/uv/tools
. The location may be customized with the UV_TOOL_DIR
environment
variable.
To display the path to the tool installation directory:
Tool environments are placed in a directory with the same name as the tool package, e.g.,
.../tools/<name>
.
Mutating tool environments#
Tool environments are not intended to be mutated directly. It is strongly recommended never to
mutate a tool environment manually with a pip
operation.
Tool environments may be upgraded via uv tool upgrade
, or re-created entirely via subsequent
uv tool install
operations.
To upgrade all packages in a tool environment
To upgrade a single package in a tool environment:
To reinstall all packages in a tool environment
To reinstall a single package in a tool environment:
Tool upgrades will respect the version constraints provided when installing the tool. For example,
uv tool install black >=23,<24
followed by uv tool upgrade black
will upgrade Black to the
latest version in the range >=23,<24
.
To instead replace the version constraints, re-install the tool with uv tool install
:
Similarly, tool upgrades will retain the settings provided when installing the tool. For example,
uv tool install black --prerelease allow
followed by uv tool upgrade black
will retain the
--prerelease allow
setting.
Tool upgrades will reinstall the tool executables, even if they have not changed.
Including additional dependencies#
Additional packages can be included during tool execution:
And, during tool installation:
The --with
option can be provided multiple times to include additional packages.
The --with
option supports package specifications, so a specific version can be requested:
If the requested version conflicts with the requirements of the tool package, package resolution will fail and the command will error.
Tool executables#
Tool executables include all console entry points, script entry points, and binary scripts provided
by a Python package. Tool executables are symlinked into the bin
directory on Unix and copied on
Windows.
The bin
directory#
Executables are installed into the user bin
directory following the XDG standard, e.g.,
~/.local/bin
. Unlike other directory schemes in uv, the XDG standard is used on all platforms
notably including Windows and macOS — there is no clear alternative location to place executables on
these platforms. The installation directory is determined from the first available environment
variable:
$UV_TOOL_BIN_DIR
$XDG_BIN_HOME
$XDG_DATA_HOME/../bin
$HOME/.local/bin
Executables provided by dependencies of tool packages are not installed.
The PATH
#
The bin
directory must be in the PATH
variable for tool executables to be available from the
shell. If it is not in the PATH
, a warning will be displayed. The uv tool update-shell
command
can be used to add the bin
directory to the PATH
in common shell configuration files.
Overwriting executables#
Installation of tools will not overwrite executables in the bin
directory that were not previously
installed by uv. For example, if pipx
has been used to install a tool, uv tool install
will
fail. The --force
flag can be used to override this behavior.
Relationship to uv run
#
The invocation uv tool run <name>
(or uvx <name>
) is nearly equivalent to:
However, there are a couple notable differences when using uv's tool interface:
- The
--with
option is not needed — the required package is inferred from the command name. - The temporary environment is cached in a dedicated location.
- The
--no-project
flag is not needed — tools are always run isolated from the project. - If a tool is already installed,
uv tool run
will use the installed version butuv run
will not.
If the tool should not be isolated from the project, e.g., when running pytest
or mypy
, then
uv run
should be used instead of uv tool run
.