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

Migration from uvx

Note: 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.

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.3.tar.gz (94.6 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.3-py3-none-musllinux_1_2_x86_64.whl (4.6 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

uvenv-3.9.3-py3-none-musllinux_1_2_aarch64.whl (4.2 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

uvenv-3.9.3-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.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (4.2 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.9.3-py3-none-macosx_10_12_x86_64.whl (4.3 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

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

File hashes

Hashes for uvenv-3.9.3.tar.gz
Algorithm Hash digest
SHA256 b9beca261ad7427207a86f189692f6e531c3692d56277f8b1ab87d90c3fe64d4
MD5 52f29fdeec929c461e970fa9fac477c2
BLAKE2b-256 d7017538ab552829c2949b682282801c3b3a3fbb1df4d786027d8f08ece3e2c3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 f62090c67b81a74452c503d74b2dd7bc39080c4b193693107cc59e56f09be409
MD5 3285714c059b6c70e142d367b4c60c35
BLAKE2b-256 ce79772727603db854c00ed1fa4485c64b0170ac2c78ef4e68e2b634f9d1537a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 80e590dfc12c52161ebf9e0e2605340247f4878c15490f33983a34c2664ed43e
MD5 a5e918ad8d4b635ef231654def184635
BLAKE2b-256 5b4a237fffbacfd710ef2fbd46d1bb248cdd36b8527545961bb115d9c2a50bbc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 44f66e0355b5ed13ac4bdcffd89139e274f995c4193ba7cf71afb510c8b4309c
MD5 12428cc656be77fd015830270c05a3a4
BLAKE2b-256 e4e299e6dc14de608ff2509a78bea006ba827a23c17f6d0bfe4e7132b46c2742

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 d46bf9cc104574a2d669629b50e472e8b136f073ea0e156cbb9f101230b5cb5a
MD5 0f90fb53151b3b9ef4d77f297a6c88a2
BLAKE2b-256 f82c0030f8a8835952f0ceeba5f4164565d1c2922db9342693d5443d168f9cbc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9aa46e9a7609062b33cd1cd83809c2c67fce96301d1044b6b38d899ab1df1873
MD5 d5a7d04d93a13cfaa5ca5016001f4d9f
BLAKE2b-256 811a9b606c3cd2c7dfb24a3160fc88b56302efff640d21d08ce4acda1e6795e2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.3-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 48d0df5f990b62bc8a15cbb256c26ed44483f008cf638a3d05a0ada24919b625
MD5 b8b2129ff0662d467a0f890557e032f1
BLAKE2b-256 f7db6f064c84eaf181e525fafa6d91d7addd808d10031821ecd50e3266df5efe

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