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

Uploaded Python 3musllinux: musl 1.2+ x86-64

uvenv-3.9.0-py3-none-musllinux_1_2_aarch64.whl (4.1 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

uvenv-3.9.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.5 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

uvenv-3.9.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (4.2 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

uvenv-3.9.0-py3-none-macosx_11_0_arm64.whl (3.9 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.9.0-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.0.tar.gz.

File metadata

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

File hashes

Hashes for uvenv-3.9.0.tar.gz
Algorithm Hash digest
SHA256 060e76c9345cd09896f00a2d9479b136a42eaf7c9da24052fba0c2b46903f6f6
MD5 95509107ddea72c2aa5e18a816bd429c
BLAKE2b-256 a4868aacb248bac4bdc7382b53923834366712075084c417c8be071a4c4c1fe9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 22f446f33130a23cce59bc2288ec847d28afc4655575ea73c62394566c7975b5
MD5 d8733b502a5f8722cd31a879cd4411c9
BLAKE2b-256 73096a6078da76a321ccf87ee99e4803b215b17d1ebe507a75b55ec41ce52d5d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 01e5d95a2b5b3a08a604f6ed1766c8fb40db4ac07d536a57e023b88bcb9d0fec
MD5 f0ed1379a66d54e1befda74344fb7b01
BLAKE2b-256 32e2391e5b8552f9c92b8bfbdf35e6b5543e528529a245e07f7127ebe668ce12

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 a7567b5136ce04c7562b95aa869c0807998093eb5e52915c39aad754e2669e82
MD5 abfc266415c3ce91dd7df6c343510f87
BLAKE2b-256 0623c7194f2420f9acc8676d7615a55571cacedd8fe4f61b6d0d238f0a784317

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 31ce91796a060be30a41dedf203a1932d896068a16f1b9bf821060e7f439e2ed
MD5 4a48b1e31179d00c5630781f2db4391c
BLAKE2b-256 0ab81d1b23e9fec53b1658c0d75fe081efdcc6fbb16977ff87c96b29de45f42f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 532d800a8d6a098b1fa72339db663ba6a6a4dd539d5088fe3b16645ccfda5394
MD5 74aab3d1ace3017232d2d91f3732cfea
BLAKE2b-256 e1c5a27ab613dea343432bee80ea99648d69f08b4e8b16bfe2f0fee5bcd1f4f6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.0-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 25ab6b349bf25f5eb7516538046effd511fe9d125866428ab5a994b6f6d5d4f6
MD5 ae6634e3d4a8aa26003ee947f6442002
BLAKE2b-256 c5d38907e19520c10a74c1b7ff10a09dd9e503158f796a384f62ed2079d3014a

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