Skip to main content

uvenv: pipx for uv (🦀)

Project description

uvenv: pipx for uv

pypi wheels snapcraft

Inspired by:

Installation

New: uvenv is now also installable via the snap store.
The pip method is still recommended, but if you want to use snap, please check out docs/snap.md!

  1. Install via pip (or alternatives):
    pip install uvenv  
    # or `uv install uvenv`, `pipx install uvenv`
    

Note: On some systems (e.g., Ubuntu 24.04+), global installation via pip is restricted by default. The recommended way to install uvenv for these systems is to use the install.sh script:

$SHELL -c "$(curl -fsSL https://raw.githubusercontent.com/robinvandernoord/uvenv/uvenv/install.sh)"
# instead of `$SHELL`, you can also use `sh`, `bash`, `zsh`
> ```
For more installation alternatives, see [docs/installation.md](docs/installation.md) if you encounter `externally-managed-environment` errors.
  1. Optional (for bash users):

    uvenv setup
    

    This installs the following features:

  • Ensures ~/.local/bin/ is added to your PATH, so commands can be found (unless --skip-ensurepath). Can also be activated via uvenv ensurepath
  • Enables tab completion for uvenv (unless --skip-completions). Can also be enabled via uvenv completions --install.
  • Enables uvenv activate (unless --skip-activate) to activate uvenv-managed virtualenvs from your shell

Usage

uvenv

Most pipx commands are supported, such as install, upgrade inject, run, runpip.
Run uvenv without any arguments to see all possible subcommands.

🆕 Freeze and Thaw

You can snapshot your current setup into a uvenv.lock file using:

uvenv freeze

This lock file records all installed applications along with their metadata — including version, Python version, and any injected dependencies.

Later, you can restore that exact setup using:

uvenv thaw

This is useful for replicating the same setup on a different machine, or after a clean install or system update.

Lock file formats

The uvenv.lock file can be saved in one of the following formats:

  • TOML (default): human-readable and easy to edit
  • JSON: more verbose, but script-friendly (e.g. with jq)
  • Binary: compact, but not human-readable

Choose the format using the --format flag:

uvenv freeze --format json

Selective freeze/thaw

Use --include or --exclude to control which apps get recorded or restored:

uvenv freeze --exclude some-app
uvenv thaw --include only-this-app

For all available options, see:

uvenv freeze --help
uvenv thaw --help

Migrating from uvx and Comparing with uv tool

Migrating from uvx

The tool previously named uvx is now uvenv due to a naming collision with a new uv command. The new name better reflects its purpose, combining uv with venv. You can run uvenv self migrate to move your environments and installed commands from uvx to uvenv.


How uvenv differs from uv tool

While both uvenv and uv tool (a subcommand of uv) offer overlapping functionality for installing and running Python applications, they differ in purpose and approach:

  • Interface: uvenv is modeled after pipx, offering commands like install, inject, run, upgrade, and runpip. If you're already used to pipx, uvenv is a near drop-in replacement.
  • Inject support: uvenv supports pipx's inject functionality, which lets you add extra packages to an app’s environment — helpful for plugins, linters, or testing tools. uv tool does not currently support this.
  • Compatibility: uvenv uses uv for dependency resolution and installation, benefiting from its speed and correctness. It also respects uv's configuration files (such as ~/.config/uv/uv.toml and /etc/uv/uv.toml, see uv config docs) unless the environment variable UV_NO_CONFIG=1 is set to ignore them.

In short:

  • Use uvenv if you want pipx-style workflows with advanced management features.
  • Use uv tool if you prefer a minimal approach for running tools quickly - for most basic use-cases, uv tool is probably sufficient.

Platform Considerations

  • Rust-Powered Performance (uvenv 2.0): Starting from version 2.0, uvenv leverages Rust for improved performance and compatibility with uv.
  • Prebuilt Binaries: Currently, prebuilt binaries are available for x86_64 (amd64) and aarch64 (ARM64) on Linux, as well as Intel (x86_64) and Apple Silicon (ARM64) on macOS.
  • Other Platforms: If you're on a different platform, you can still use uvx 1.x, which is written in pure Python. Find it at robinvandernoord/uvx.
  • Alternatively, you can Compile for Your Platform:
    • Install the Rust toolchain:
      curl https://sh.rustup.rs -sSf | sh
      
    • Clone the uvenv repo and navigate to it:
      git clone https://github.com/robinvandernoord/uvenv.git
      cd uvenv
      
    • Set up a virtual environment (choose Python or uv):
      python -m venv venv  # or `uv venv venv --seed`
      source venv/bin/activate
      
    • Install Maturin (Python with Rust package builder):
      pip install maturin  # or `uv pip install maturin`
      
    • Compile and install the uvenv binary:
      maturin develop
      
    • Now you can use uvenv:
      ./venv/bin/uvenv
      

For additional details on building and distribution, refer to maturin documentation.

License

uvenv is distributed under the terms of the MIT license.

Changelog

See CHANGELOG.md on GitHub

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

uvenv-3.9.17.tar.gz (97.7 kB view details)

Uploaded Source

Built Distributions

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

uvenv-3.9.17-py3-none-musllinux_1_2_x86_64.whl (4.6 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

uvenv-3.9.17-py3-none-musllinux_1_2_aarch64.whl (4.3 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

uvenv-3.9.17-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.6 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

uvenv-3.9.17-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (4.3 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

uvenv-3.9.17-py3-none-macosx_11_0_arm64.whl (4.0 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.9.17-py3-none-macosx_10_12_x86_64.whl (4.4 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

Details for the file uvenv-3.9.17.tar.gz.

File metadata

  • Download URL: uvenv-3.9.17.tar.gz
  • Upload date:
  • Size: 97.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/1.9.1

File hashes

Hashes for uvenv-3.9.17.tar.gz
Algorithm Hash digest
SHA256 d24a127643e3e809cb3bc56d9aa12406b753ebf627683dde07bea42c30a24ba2
MD5 35904ad59e730d49c4d98364adb90dd4
BLAKE2b-256 91547c72d1aec610eeb380b0dccfbcbcb0d6ae1b34ee74ef07892e18685d39bc

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-musllinux_1_2_x86_64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 55c4abd33b0ec9a1e9d94a20cfc62196d36a8fb73a862e4f7ce10ebb851d6428
MD5 0a68ea9094f4463981f22cfa12c3f690
BLAKE2b-256 afaa39a41604b91b8499d5e94a12a3e9d1183d866139e924d2e1dad7770d12a1

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-musllinux_1_2_aarch64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 b10ebc587cb7ffef534ea629fd13c2a67acfb7bd44f5ddcf28bd852bd7392e64
MD5 dd3d68f23bf35a50bef0dfdb4138f421
BLAKE2b-256 2a0681e73f2f2fe4d08de51198831d35c696d009bab38506b870502ef5399543

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 32019f1458d0b0f4fd1e2a5d8c40c0d6a19e539d450ab28a1b8270c9d940fa2d
MD5 d1109da769423aa7d4ca18212e499a2f
BLAKE2b-256 47fb58b6f6405fff0189b7300d18930b6843be3373be29af6ac51ef7edd9ae4c

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f611499778f88bc916b39ed3738a6b906e6093a6116caef5c2ef483e3c0c3a26
MD5 1bc4017eb8e9030e89ec1d07500d48c6
BLAKE2b-256 82e543c4115b110e63aaeeb32ea664c322540095c0f86cba036a6beb0ce1ef10

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 06b4d1cb6f445219b49d53605d94371e9d43b56f2da77d06979bbe44b16d2d8b
MD5 50d114b3b448712091ecb12f0fe172c3
BLAKE2b-256 13ec5902ae280f9088637c6f362d42e1cf4e3a5ff6eb2d6ae100ae04728f1428

See more details on using hashes here.

File details

Details for the file uvenv-3.9.17-py3-none-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for uvenv-3.9.17-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 7bb26ff605b39f9bbf24abfd8d60a132827824f056a5deb0da43665ac2fa5496
MD5 3f1d17a546c9766dad2ed47b95172e56
BLAKE2b-256 57fccea1402dc35029314d2282084c463618f4fac80845f3c2a7736a9a1e7c56

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