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.4.tar.gz (94.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.4-py3-none-musllinux_1_2_x86_64.whl (4.5 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

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

Uploaded Python 3musllinux: musl 1.2+ ARM64

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

Uploaded Python 3manylinux: glibc 2.17+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.9.4-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.4.tar.gz.

File metadata

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

File hashes

Hashes for uvenv-3.9.4.tar.gz
Algorithm Hash digest
SHA256 dbfc5c24bad1ef21581efe9e0ad4edd1b7972d867500d5ddd319284ed9cb956e
MD5 e3731fa6866a60bb1ec442ccef877535
BLAKE2b-256 d57fbb04c97c52b1e3a0eb6d3a37d3518adf5df3421d9caf4da31ab8101db137

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 5b607775db54fae334af6d3cdefb2b5afe2d5384e4a6cb1f41a72d89dd5021c3
MD5 9d83b546245f6e2f75853db1bd1dc8e9
BLAKE2b-256 327949e6012c519fce335cd0fd440d9907c8d93cd77cb5b29f8383e64454eda5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 d157dfb2eeac26a8dcadb607eb85b14e0ce38d875903f3f399968165228dda30
MD5 6aa632ddd6a53f76a386933452ed4c01
BLAKE2b-256 5f3750c1f8d52911b5a964e68fdfed499e82b9475399deb92d6825c6bcc158ad

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6410dde7ccfa92d1a38daf5dc5fbef4a8f34cf5d3d1d8d114768a0734ea33395
MD5 484ef012fd6a0ad8bc5b093ab3dde20f
BLAKE2b-256 ee4833e35a1294b909975b817bd1f848863fd7f453567ae1f900f6c70fc06fb4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 5840dc1daf3ef06799230c4515e7fc959492d12479f7f70da7636442cd26a9c5
MD5 90b0772c7e1ef07fba9447f5069afb83
BLAKE2b-256 55719342caa0e5d0f87c4fe1812cb0553544d6cfb1950076e5ec190d741d97bd

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 942e2f9361dcf619081ae94ef80eb7a9e596944215014b416b589fbb0556e0ee
MD5 ebb70bc160f626f606c9c899c6e11d3c
BLAKE2b-256 e26090fe4e0af217dd167fdf2b913e8d0b95888e28a4a280f0dcf17c1475f137

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.4-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 a3b910678b075909bc7ce4c250647a87a7d172e97d912071e9643f2f554c0273
MD5 994555a99055ebf58d91a2d583b35ee0
BLAKE2b-256 05835be01896539880a72cc2e52319ae9d2dc1e085107e63249091c9239d5700

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