Skip to main content

uvenv: pipx for uv (🦀)

Project description

uvenv: pipx for uv

Inspired by:

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.

Installation

  1. Install via pip (or alternatives):
    pip install uvenv  
    # or `uv install uvenv`, `pipx install uvenv`
    

Note: Ubuntu 24.04+ does not allow global installation via pip by default. See docs/ubuntu_2404.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

Run uvenv without any arguments to see all possible subcommands.

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.7.0.tar.gz (79.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.7.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.1 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

uvenv-3.7.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (3.9 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

uvenv-3.7.0-py3-none-macosx_11_0_arm64.whl (3.6 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

uvenv-3.7.0-py3-none-macosx_10_12_x86_64.whl (4.0 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

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

File hashes

Hashes for uvenv-3.7.0.tar.gz
Algorithm Hash digest
SHA256 73c55f05fbdd88421fbde721c1d30b888f5ba32ad6a772eca591c08978d356f9
MD5 bbe431c00d212b38c5518f14857fff0f
BLAKE2b-256 487f4b9e4c5e0cbcd3cc0f0f1e4dfe61a67346abd4b3c61f282cba6e23d28970

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.7.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c19748ade145278a5d9a4948acf5c33f7755713d08d8d844536af546bc92953e
MD5 1a0e918bf4a5426fcdc1992e03e1246d
BLAKE2b-256 c3db8c05ceaeff794f7d1bf9218f2cb7dbb39e45d3a3441bf5389c4a528d0d68

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.7.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 17ca5faba13d9b0f03c777ab299c038158b9d10f0089f4ef147ab3206dc1b18f
MD5 97764e5cde156e0467cdf4171da19ba9
BLAKE2b-256 c8d2ddde9fe07deca56f77184824abec3c5b43bda80d04663754cffb859f0eb8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.7.0-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6641c7d3470fe8ef3032ecf588dbaa6c7be34c8c3b6997ce8ce3b370b763aced
MD5 07ce5cdf58bd0b1392cb80bcabd3fb84
BLAKE2b-256 08b718eb34376e5cf2116246af27dd6b5162feffa87ac009641f448a1466f4a2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for uvenv-3.7.0-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 a214f8d9ebd0c8722a0e4bcd93af1eeb33ba643a50933015122982484fa1c64c
MD5 6f96fe71fb116c3a2495c894a3013c19
BLAKE2b-256 372aa38a54cd4a662082b881b801e35ef980498e0e47173eb7ed456d0318db49

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