Skip to main content

An extremely fast Python package installer and resolver, written in Rust.

Project description

uv

uv image image image Actions status Discord

An extremely fast Python package installer and resolver, written in Rust. Designed as a drop-in replacement for common pip and pip-tools workflows.

uv is backed by Astral, the creators of Ruff.

Highlights

  • ⚖️ Drop-in replacement for common pip, pip-tools, and virtualenv commands.
  • ⚡️ 10-100x faster than pip and pip-tools (pip-compile and pip-sync).
  • 💾 Disk-space efficient, with a global cache for dependency deduplication.
  • 🐍 Installable via curl, pip, pipx, etc. uv is a static binary that can be installed without Rust or Python.
  • 🧪 Tested at-scale against the top 10,000 PyPI packages.
  • 🖥️ Support for macOS, Linux, and Windows.
  • 🧰 Advanced features such as dependency version overrides and alternative resolution strategies.
  • ⁉️ Best-in-class error messages with a conflict-tracking resolver.
  • 🤝 Support for a wide range of advanced pip features, including editable installs, Git dependencies, direct URL dependencies, local dependencies, constraints, source distributions, HTML and JSON indexes, and more.

Getting Started

Install uv with our standalone installers, or from PyPI:

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

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

# With pip.
pip install uv

# With pipx.
pipx install uv

# With Homebrew.
brew install uv

# With Pacman.
pacman -S uv

To create a virtual environment:

uv venv  # Create a virtual environment at .venv.

To activate the virtual environment:

# On macOS and Linux.
source .venv/bin/activate

# On Windows.
.venv\Scripts\activate

To install a package into the virtual environment:

uv pip install flask                # Install Flask.
uv pip install -r requirements.txt  # Install from a requirements.txt file.
uv pip install -e .                 # Install the current project in editable mode.
uv pip install "package @ ."        # Install the current project from disk
uv pip install "flask[dotenv]"      # Install Flask with "dotenv" extra.

To generate a set of locked dependencies from an input file:

uv pip compile pyproject.toml -o requirements.txt   # Read a pyproject.toml file.
uv pip compile requirements.in -o requirements.txt  # Read a requirements.in file.

To sync a set of locked dependencies with the virtual environment:

uv pip sync requirements.txt  # Install from a requirements.txt file.

uv's pip-install and pip-compile commands support many of the same command-line arguments as existing tools, including -r requirements.txt, -c constraints.txt, -e . (for editable installs), --index-url, and more.

Limitations

While uv supports a large subset of the pip interface, it does not support the entire feature set. In some cases, those differences are intentional; in others, they're a result of uv's early stage of development.

For details, see our pip compatibility guide.

Like pip-compile, uv generates a platform-specific requirements.txt file (unlike, e.g., poetry and pdm, which generate platform-agnostic poetry.lock and pdm.lock files). As such, uv's requirements.txt files may not be portable across platforms and Python versions.

Roadmap

uv is an extremely fast Python package resolver and installer, designed as a drop-in replacement for pip, pip-tools (pip-compile and pip-sync), and virtualenv.

uv represents an intermediary goal in our pursuit of a "Cargo for Python": a comprehensive project and package manager that is extremely fast, reliable, and easy to use.

Think: a single binary that bootstraps your Python installation and gives you everything you need to be productive with Python, bundling not only pip, pip-tools, and virtualenv, but also pipx, tox, poetry, pyenv, ruff, and more.

Our goal is to evolve uv into such a tool.

In the meantime, though, the narrower pip-tools scope allows us to solve the low-level problems involved in building such a tool (like package installation) while shipping something immediately useful with a minimal barrier to adoption.

Advanced Usage

Python discovery

uv itself does not depend on Python, but it does need to locate a Python environment to (1) install dependencies into the environment and (2) build source distributions.

When running pip sync or pip install, uv will search for a virtual environment in the following order:

  • An activated virtual environment based on the VIRTUAL_ENV environment variable.
  • An activated Conda environment based on the CONDA_PREFIX environment variable.
  • A virtual environment at .venv in the current directory, or in the nearest parent directory.

If no virtual environment is found, uv will prompt the user to create one in the current directory via uv venv.

When running pip compile, uv does not require a virtual environment and will search for a Python interpreter in the following order:

  • An activated virtual environment based on the VIRTUAL_ENV environment variable.
  • An activated Conda environment based on the CONDA_PREFIX environment variable.
  • A virtual environment at .venv in the current directory, or in the nearest parent directory.
  • The Python interpreter available as python3 on macOS and Linux, or python.exe on Windows.

If a --python-version is provided to pip compile (e.g., --python-version=3.7), uv will search for a Python interpreter matching that version in the following order:

  • An activated virtual environment based on the VIRTUAL_ENV environment variable.
  • An activated Conda environment based on the CONDA_PREFIX environment variable.
  • A virtual environment at .venv in the current directory, or in the nearest parent directory.
  • The Python interpreter available as, e.g., python3.7 on macOS and Linux.
  • The Python interpreter available as python3 on macOS and Linux, or python.exe on Windows.
  • On Windows, the Python interpreter returned by py --list-paths that matches the requested version.

Installing into arbitrary Python environments

Since uv has no dependency on Python, it can even install into virtual environments other than its own. For example, setting VIRTUAL_ENV=/path/to/venv will cause uv to install into /path/to/venv, no matter where uv is installed.

uv can also install into arbitrary, even non-virtual environments by providing a --python argument to uv pip sync or uv pip install. For example, uv pip install --python=/path/to/python will install into the environment linked to the /path/to/python interpreter.

For convenience, uv pip install --system will install into the system Python environment, as an approximate shorthand for, e.g., uv pip install --python=$(which python3). Though we generally recommend the use of virtual environments for dependency management, --system is intended to enable the use of uv in continuous integration and containerized environments.

Installing into system Python across platforms and distributions is notoriously difficult. uv supports the common cases, but will not work in all cases. For example, installing into system Python on Debian prior to Python 3.10 is unsupported due to the distribution's patching of distutils (but not sysconfig). While we always recommend the use of virtual environments, uv considers them to be required in these non-standard environments.

Git authentication

uv allows packages to be installed from Git and supports the following schemes for authenticating with private repositories.

Using SSH:

  • git+ssh://git@<hostname>/... (e.g. git+ssh://git@github.com/astral-sh/uv)
  • git+ssh://git@<host>/... (e.g. git+ssh://git@github.com-key-2/astral-sh/uv)

See the GitHub SSH documentation for more details on how to configure SSH.

Using a password or token:

  • git+https://<user>:<token>@<hostname>/... (e.g. git+https://git:github_pat_asdf@github.com/astral-sh/uv)
  • git+https://<token>@<hostname>/... (e.g. git+https://github_pat_asdf@github.com/astral-sh/uv)
  • git+https://<user>@<hostname>/... (e.g. git+https://git@github.com/astral-sh/uv)

When using a GitHub personal access token, the username is arbitrary. GitHub does not support logging in with password directly, although other hosts may. If a username is provided without credentials, you will be prompted to enter them.

If there are no credentials present in the URL and authentication is needed, the Git credential helper will be queried.

Dependency caching

uv uses aggressive caching to avoid re-downloading (and re-building dependencies) that have already been accessed in prior runs.

The specifics of uv's caching semantics vary based on the nature of the dependency:

  • For registry dependencies (like those downloaded from PyPI), uv respects HTTP caching headers.
  • For direct URL dependencies, uv respects HTTP caching headers, and also caches based on the URL itself.
  • For Git dependencies, uv caches based on the fully-resolved Git commit hash. As such, uv pip compile will pin Git dependencies to a specific commit hash when writing the resolved dependency set.
  • For local dependencies, uv caches based on the last-modified time of the setup.py or pyproject.toml file.

If you're running into caching issues, uv includes a few escape hatches:

  • To force uv to revalidate cached data for all dependencies, run uv pip install --refresh ....
  • To force uv to revalidate cached data for a specific dependency, run, e.g., uv pip install --refresh-package flask ....
  • To force uv to ignore existing installed versions, run uv pip install --reinstall ....
  • To clear the global cache entirely, run uv cache clean.

Resolution strategy

By default, uv follows the standard Python dependency resolution strategy of preferring the latest compatible version of each package. For example, uv pip install flask>=2.0.0 will install the latest version of Flask (at time of writing: 3.0.0).

However, uv's resolution strategy can be configured to support alternative workflows. With --resolution=lowest, uv will install the lowest compatible versions for all dependencies, both direct and transitive. Alternatively, --resolution=lowest-direct will opt for the lowest compatible versions for all direct dependencies, while using the latest compatible versions for all transitive dependencies. This distinction can be particularly useful for library authors who wish to test against the lowest supported versions of direct dependencies without restricting the versions of transitive dependencies.

For example, given the following requirements.in file:

flask>=2.0.0

Running uv pip compile requirements.in would produce the following requirements.txt file:

# This file was autogenerated by uv via the following command:
#    uv pip compile requirements.in
blinker==1.7.0
    # via flask
click==8.1.7
    # via flask
flask==3.0.0
itsdangerous==2.1.2
    # via flask
jinja2==3.1.2
    # via flask
markupsafe==2.1.3
    # via
    #   jinja2
    #   werkzeug
werkzeug==3.0.1
    # via flask

However, uv pip compile --resolution=lowest requirements.in would instead produce:

# This file was autogenerated by uv via the following command:
#    uv pip compile requirements.in --resolution=lowest
click==7.1.2
    # via flask
flask==2.0.0
itsdangerous==2.0.0
    # via flask
jinja2==3.0.0
    # via flask
markupsafe==2.0.0
    # via jinja2
werkzeug==2.0.0
    # via flask

Pre-release handling

By default, uv will accept pre-release versions during dependency resolution in two cases:

  1. If the package is a direct dependency, and its version markers include a pre-release specifier (e.g., flask>=2.0.0rc1).
  2. If all published versions of a package are pre-releases.

If dependency resolution fails due to a transitive pre-release, uv will prompt the user to re-run with --prerelease=allow, to allow pre-releases for all dependencies.

Alternatively, you can add the transitive dependency to your requirements.in file with pre-release specifier (e.g., flask>=2.0.0rc1) to opt in to pre-release support for that specific dependency.

Pre-releases are notoriously difficult to model, and are a frequent source of bugs in other packaging tools. uv's pre-release handling is intentionally limited and intentionally requires user opt-in for pre-releases, to ensure correctness.

For more, see "Pre-release compatibility"

Dependency overrides

Historically, pip has supported "constraints" (-c constraints.txt), which allows users to narrow the set of acceptable versions for a given package.

uv supports constraints, but also takes this concept further by allowing users to override the acceptable versions of a package across the dependency tree via overrides (--override overrides.txt).

In short, overrides allow the user to lie to the resolver by overriding the declared dependencies of a package. Overrides are a useful last resort for cases in which the user knows that a dependency is compatible with a newer version of a package than the package declares, but the package has not yet been updated to declare that compatibility.

For example, if a transitive dependency declares pydantic>=1.0,<2.0, but the user knows that the package is compatible with pydantic>=2.0, the user can override the declared dependency with pydantic>=2.0,<3 to allow the resolver to continue.

While constraints are purely additive, and thus cannot expand the set of acceptable versions for a package, overrides can expand the set of acceptable versions for a package, providing an escape hatch for erroneous upper version bounds.

Multi-version resolution

uv's pip-compile command produces a resolution that's known to be compatible with the current platform and Python version. Unlike Poetry, PDM, and other package managers, uv does not yet produce a machine-agnostic lockfile.

However, uv does support resolving for alternate Python versions via the --python-version command line argument. For example, if you're running uv on Python 3.9, but want to resolve for Python 3.8, you can run uv pip compile --python-version=3.8 requirements.in to produce a Python 3.8-compatible resolution.

Reproducible resolution

uv supports an --exclude-newer option to limit resolution to distributions published before a specific date, allowing reproduction of installations regardless of new package releases. The date may be specified as a RFC 3339 timestamp (e.g., 2006-12-02T02:07:43Z) or UTC date in the same format (e.g., 2006-12-02).

Note the package index must support the upload-time field as specified in PEP 700. If the field is not present for a given distribution, the distribution will be treated as unavailable.

To ensure reproducibility, messages for unsatisfiable resolutions will not mention that distributions were excluded due to the --exclude-newer flag — newer distributions will be treated as if they do not exist.

Platform support

uv has Tier 1 support for the following platforms:

  • macOS (Apple Silicon)
  • macOS (x86_64)
  • Linux (x86_64)
  • Windows (x86_64)

uv is continuously built, tested, and developed against its Tier 1 platforms. Inspired by the Rust project, Tier 1 can be thought of as "guaranteed to work".

uv has Tier 2 support ("guaranteed to build") for the following platforms:

  • Linux (PPC64)
  • Linux (PPC64LE)
  • Linux (aarch64)
  • Linux (armv7)
  • Linux (i686)
  • Linux (s390x)

uv ships pre-built wheels to PyPI for its Tier 1 and Tier 2 platforms. However, while Tier 2 platforms are continuously built, they are not continuously tested or developed against, and so stability may vary in practice.

Beyond the Tier 1 and Tier 2 platforms, uv is known to build on i686 Windows, and known not to build on aarch64 Windows, but does not consider either platform to be supported at this time.

uv supports and is tested against Python 3.8, 3.9, 3.10, 3.11, and 3.12.

Custom CA Certificates

uv supports custom CA certificates (such as those needed by corporate proxies) by utilizing the system's trust store. To ensure this works out of the box, ensure your certificates are added to the system's trust store.

If a direct path to the certificate is required (e.g., in CI), set the SSL_CERT_FILE environment variable to the path of the certificate bundle, to instruct uv to use that file instead of the system's trust store.

Acknowledgements

uv's dependency resolver uses PubGrub under the hood. We're grateful to the PubGrub maintainers, especially Jacob Finkelman, for their support.

uv's Git implementation is based on Cargo.

Some of uv's optimizations are inspired by the great work we've seen in pnpm, Orogene, and Bun. We've also learned a lot from Nathaniel J. Smith's Posy and adapted its trampoline for Windows support.

License

uv is licensed under either of

at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in uv by you, as defined in the Apache-2.0 license, shall be dually licensed as above, without any additional terms or conditions.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uv-0.1.16.tar.gz (532.8 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

uv-0.1.16-py3-none-win_amd64.whl (8.6 MB view details)

Uploaded Python 3Windows x86-64

uv-0.1.16-py3-none-win32.whl (7.5 MB view details)

Uploaded Python 3Windows x86

uv-0.1.16-py3-none-musllinux_1_2_x86_64.whl (10.9 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

uv-0.1.16-py3-none-musllinux_1_2_i686.whl (10.3 MB view details)

Uploaded Python 3musllinux: musl 1.2+ i686

uv-0.1.16-py3-none-musllinux_1_2_armv7l.whl (9.1 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARMv7l

uv-0.1.16-py3-none-musllinux_1_2_aarch64.whl (10.4 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

uv-0.1.16-py3-none-manylinux_2_28_armv7l.whl (9.1 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ ARMv7l

uv-0.1.16-py3-none-manylinux_2_28_aarch64.whl (10.5 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ ARM64

uv-0.1.16-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.8 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

uv-0.1.16-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl (11.2 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ s390x

uv-0.1.16-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (11.3 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ppc64le

uv-0.1.16-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (11.8 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ppc64

uv-0.1.16-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl (10.9 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ i686

uv-0.1.16-py3-none-macosx_10_12_x86_64.whl (9.9 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

uv-0.1.16-py3-none-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (19.8 MB view details)

Uploaded Python 3macOS 10.12+ universal2 (ARM64, x86-64)macOS 10.12+ x86-64macOS 11.0+ ARM64

File details

Details for the file uv-0.1.16.tar.gz.

File metadata

  • Download URL: uv-0.1.16.tar.gz
  • Upload date:
  • Size: 532.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16.tar.gz
Algorithm Hash digest
SHA256 9e68364db010ba000d670a7db0490d293241ad0322297d0e1ed9d786c8edc7c3
MD5 104f4bb4fe9261ed39d8b1a4eb7daa4d
BLAKE2b-256 ec47e10ecb9706979a9e186cd19e22a66009499f0c7363f3df9ea574089ba733

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-win_amd64.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-win_amd64.whl
  • Upload date:
  • Size: 8.6 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 43fc9dfca0f191fc95850f2dcf17c394d43ffe828624389d53cc057176804720
MD5 52048d2759c5c90edf3224949555765d
BLAKE2b-256 6539aa684acb8a85a05c59b4fc4b1ea45618c271febe9ef9416492c3aaa9ce5f

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-win32.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-win32.whl
  • Upload date:
  • Size: 7.5 MB
  • Tags: Python 3, Windows x86
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-win32.whl
Algorithm Hash digest
SHA256 f2f0c756a2ebc10674d769974fff32ac22e90786e3870b586c03f60ea5e1a7c5
MD5 24993cefeb88eb9c70482f889be4cbbc
BLAKE2b-256 15f6f3a398f84e5c504ef86dfbacf539dda43eaf069d239e16f537c6cd881b84

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-musllinux_1_2_x86_64.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-musllinux_1_2_x86_64.whl
  • Upload date:
  • Size: 10.9 MB
  • Tags: Python 3, musllinux: musl 1.2+ x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 d32b2d2cf7b15dbab5fba025133c1fda6609d04a0f39fb0d8fec458f29e075a9
MD5 766f0377cbc86e2962f5567549c3b83b
BLAKE2b-256 cb60bb17d54a595477ce18d4ddfcca74a7a9b0a82cdeda271bb4856f7ca2df17

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-musllinux_1_2_i686.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-musllinux_1_2_i686.whl
  • Upload date:
  • Size: 10.3 MB
  • Tags: Python 3, musllinux: musl 1.2+ i686
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-musllinux_1_2_i686.whl
Algorithm Hash digest
SHA256 8240b48d11ace229e4e164969588bab022f1036fb75a4fd4938e2f8fbfd620de
MD5 52730306bb28331a27a9716fcfffaf5d
BLAKE2b-256 4dc22c943eae409df5baf97c80759fe53b4605a46688282cb6fdbe145f5472d9

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-musllinux_1_2_armv7l.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-musllinux_1_2_armv7l.whl
  • Upload date:
  • Size: 9.1 MB
  • Tags: Python 3, musllinux: musl 1.2+ ARMv7l
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-musllinux_1_2_armv7l.whl
Algorithm Hash digest
SHA256 6d39b23091e3f88b81d5f4e7044d62ea78ac8ab59a9e4ddfcb78808a0c9c46a3
MD5 9a1c04f6399c49c3d9c5f20e2ec19dde
BLAKE2b-256 e24dda2a0133d05be1733b66006d82d94b418baed97c9244dcd10dec5e42f9b8

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-musllinux_1_2_aarch64.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-musllinux_1_2_aarch64.whl
  • Upload date:
  • Size: 10.4 MB
  • Tags: Python 3, musllinux: musl 1.2+ ARM64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 e82feb94345b41e7547d0c89336a1a50c11670756a6e7cc1071e6821367bf763
MD5 afca8ad9a51274d02604647f48f916ba
BLAKE2b-256 6b81397d739b01f457944981af1727b67f19c09969782fc573028ad183d27494

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_28_armv7l.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-manylinux_2_28_armv7l.whl
  • Upload date:
  • Size: 9.1 MB
  • Tags: Python 3, manylinux: glibc 2.28+ ARMv7l
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_28_armv7l.whl
Algorithm Hash digest
SHA256 6b18125394d9c6256102ed5a1d6cbe6293253d5a2eeefb2d10dd8aeeefac4cdc
MD5 a29875b5bc9c6aac6cbf2a12e9081d5f
BLAKE2b-256 fa1a00271ad4d18cd725e8855a4fbccb008bcd72af2a477e750d381b879c7455

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_28_aarch64.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-manylinux_2_28_aarch64.whl
  • Upload date:
  • Size: 10.5 MB
  • Tags: Python 3, manylinux: glibc 2.28+ ARM64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 7395fb32f235ceb3b12f3f183aa375c38af30134a2a4474c10f6bbcdeed6e8d2
MD5 0862894387ad1f3304224ea6de2083f3
BLAKE2b-256 d7056aaa27d27a39a773449eb1cd378408d8074a7f66cd45fff03d5dbc5f86f6

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f89611a1b2f15861aea6c9dbe4121008dcbe7c200a7471228f866384d8859dd4
MD5 e1ddee2ebb3524f94f6d68369e41e3a6
BLAKE2b-256 1c6bd8814d6216d596a292b5b93e69807866cbe0f4ec81d3de927e17d433d903

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl
Algorithm Hash digest
SHA256 ae968af14128026d16b37280621f09b006104236c18e57650cd8809de3a7aff4
MD5 8b288079da0ee34a6c6508795b4bc567
BLAKE2b-256 d3decaa9a0cee9b5ede223fe5817a22a564e2c21dff7109f98c19ee7d9ada033

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl
Algorithm Hash digest
SHA256 024a0f79a15743bbb9fe76a7bb52d389348643189d4802b6fd44383b04bee856
MD5 7514f02613a49b855237fce4f6bbb407
BLAKE2b-256 dfc27be8fa0eda6971ec56d69daa1eb2d436b45c41170ada0a41091a9c267931

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl
Algorithm Hash digest
SHA256 dc5b8d5cd778bd72322c95ad630bac3f91787d9c925dfbd7a589f6e0f5022ff7
MD5 1e3c8c9dc55a8d3648897ba560bce20a
BLAKE2b-256 41fa7b1293862a5162deb2e665095c2d4c5c71e630749af94af9959a93fdd3f4

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl
Algorithm Hash digest
SHA256 3ce0243cfde8b0dbcc45df8d67abcd1044779b1d388d9b0d49d00ce365d168d9
MD5 7e37968cd96375bedb404b57fcf3e771
BLAKE2b-256 ff70f2d944fcb79f805a314b23445a69ffd5a93915e598469cb130635637c4c7

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-macosx_10_12_x86_64.whl.

File metadata

  • Download URL: uv-0.1.16-py3-none-macosx_10_12_x86_64.whl
  • Upload date:
  • Size: 9.9 MB
  • Tags: Python 3, macOS 10.12+ x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for uv-0.1.16-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 8e8251b20a3d6ccd3d81e46fcd43eb692458b045faf5772429e4ed280490214d
MD5 8f5ea62d5a62ca48bb0017154cdd1944
BLAKE2b-256 23bd3b9903bfe592d56e3f69aa3f4aea05c3ccae7dc0c485d288efac54201aac

See more details on using hashes here.

File details

Details for the file uv-0.1.16-py3-none-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl.

File metadata

File hashes

Hashes for uv-0.1.16-py3-none-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl
Algorithm Hash digest
SHA256 d01cd6c33b81d04301e69a199cfacc2835d3a2541f2c605c3502a9ea6f340271
MD5 78a672f3d7a0169a751ef62e128f3f17
BLAKE2b-256 8bca4d4d6a5ffe9c5aa552b67663416f3e7bf722bb62a676d04b1bb785e7424b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page