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.6.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.6-py3-none-musllinux_1_2_x86_64.whl (4.5 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

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

Uploaded Python 3musllinux: musl 1.2+ ARM64

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

Uploaded Python 3manylinux: glibc 2.17+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.9.6-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.6.tar.gz.

File metadata

  • Download URL: uvenv-3.9.6.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.6.tar.gz
Algorithm Hash digest
SHA256 1b196ec9d080a93899587a85cfc3599c67ed02d8aef3fe2a8643cc84a0cf2cb4
MD5 3915999d7043eb9526a3b7358068bea6
BLAKE2b-256 3831c204246ac39896c0398f5eaa9e1dfabcca342fcfb352017f63949681672e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 3578b50ff56af8982c650a2488d0986915c6152e4ea8987b3771b8c991005c91
MD5 dc77290b8f58877b6b3fd5e4dfdeaa00
BLAKE2b-256 732a9f7eb88d61b0f3ecc0a93273d97e07872d1ceae7fc32215e3c94fd02db32

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 3753ba7284b6c148132cd44a47fb75abbecdbb8fefefcdd083281971884621be
MD5 f19ded0aaa2e89bd4c9b15c5c22d3332
BLAKE2b-256 dbca10053d95011bad9f4046b4abfb9538c41d861fddb75b88464ca4d7798579

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c3d4ca9a240782b3b564fb2389d9144cca1adfc8b5460f5c0986d49add338a8e
MD5 492f9af10536109e94ae773b8bbf75f6
BLAKE2b-256 069ab66ebf34bbbb75769898745ccf983007aa9b9acde5ef7ce1367edc554901

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 59662ef9af9b66f005384c117080bb1fd01f7b06e84ab92263b19355bf8d1ebd
MD5 29660e8372db6c43541e6e8405e8cacd
BLAKE2b-256 a8add6bb94e97501f19e9447b0797f93589e5139449435aee6e2c2484543ddb4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6470015403092e1bdafd7af9436272f0ec1e6be9d28db73b52db3eb6b68c6af8
MD5 76416a80e087b0fefb571b39431f6a4d
BLAKE2b-256 ed9e5ac05e242e0fcc5a31000c9fd77e0234015728cad4c9b8500bbeea53aae3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.9.6-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 1071bd6a02336b4616631e1bffe5b957ab07f0f9d7727186d0453896185ae72d
MD5 71f310cfd2e00af074d8ed54c90d26fe
BLAKE2b-256 d32fcc970da5d082884fb61c5eca244623524da3f6887d49c3fc71f3a685333a

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