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.8.4.tar.gz (91.1 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.8.4-py3-none-musllinux_1_2_x86_64.whl (4.4 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

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

Uploaded Python 3musllinux: musl 1.2+ ARM64

uvenv-3.8.4-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.4 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

uvenv-3.8.4-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (4.1 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.8.4-py3-none-macosx_10_12_x86_64.whl (4.2 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

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

File hashes

Hashes for uvenv-3.8.4.tar.gz
Algorithm Hash digest
SHA256 4b35266ef764cea612552c8174ccb5ef1f17a05ba8b464bf1ef21d5f07b59347
MD5 6650b26d14404b37baebfed73a696610
BLAKE2b-256 725e9c30644e863c6d5ac8537a7a26716fdaf5d0de0f95b462595fd46871bb8a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 e1cd36023e89e0eff8c054f0553dd2fd7d805c7f84ebb11dc6776cdf4b7e2da8
MD5 287d2ed0be999f6cb324bf77bb9a4dd4
BLAKE2b-256 af63aa69cc76e4af50ce0c9539284985c65583940e48c6078202855e62ab9353

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 42a3157b96c8b49b06271082c1075320305d71d819d14df6269c108e8683fbb2
MD5 6c4a96d5b662e3a90b9c071b6cb950bb
BLAKE2b-256 0aca61c1e0d348b9bd65ebbca08d5f2be9445f2b8eb99fded738e76a83abf0dc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 900a9120395f5658ba0f920ab65498688570c8a3f3905fbe9defb94b3c38ce13
MD5 23d48b301ed82eda5a1969f77bc0a33f
BLAKE2b-256 54004725dc2453fd2991a1d82d82c79b4228da1b102e56c10522dc443458ded5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f0991f759802cf5c36723b67cc639ae21327e2b3df6a28d2f2ee1e830e6d3a73
MD5 a23fae2763f7cf047030f0f5e8340ef6
BLAKE2b-256 223f21a69215fe8af9ef18e55514130a49d86438098f4bfbb8ca5a624b924bc9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 7a9a247d506d4ae964f0e38d9a247da4a1fd57e5abcf4f7d45bd745c2110e601
MD5 71115dde4a09cfa786a7293077bef0ea
BLAKE2b-256 efdf5568be44e9a6e970365f5a9cda6ab01ff1094c4c0e4a32122a7a2842701b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.8.4-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 23b78db7c6db60a65571a89bc6ea03e648275df0bbfcea465d14efda6342100e
MD5 384d8ee3f68edfd91ed880615bd8584d
BLAKE2b-256 e2e88fa584e767315b0ed6f4affb3d4cc444dbe7d32836a2a2899e7bfa8c9764

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