Skip to content

afaikiac/pyenvx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 

Repository files navigation

PyenvX

This script is inspired by pipx, but it's designed to work seamlessly with pyenv. It allows you to install and manage the latest versions of CLI or GUI tools, such as pdm, poetry, or Anki, while utilizing the power of pyenv. There's no need to install a massive amount of Python dependencies through your package manager!

Requirements

pyenv bash curl git

Installation

Last commit version

bash -c 'FILE="$HOME/.local/bin/pyenvx"; curl -fsSL https://raw.githubusercontent.com/afaikiac/pyenvx/main/pyenvx.bash -o "$FILE" && chmod +x "$FILE" && echo "pyenvx was installed!"'

Last release version

bash -c 'FILE="$HOME/.local/bin/pyenvx"; curl -fsSL https://github.com/afaikiac/pyenvx/releases/latest/download/pyenvx.bash -o "$FILE" && chmod +x "$FILE" && echo "pyenvx was installed!"'

Usage

pyenvx --help
A script to manage Python packages with their own virtual environments
using pyenv and pyenv-virtualenv.

Usage:
    pyenvx install package1 [package2 ...]
        Install the specified package(s) in separate virtual environments.
        And add virtual environments to global. If a virtual environment for
        a package already exists, the script will prompt you to recreate it.
  
    pyenvx update package1 [package2 ...]
        Update the specified package(s) in their respective virtual
        environments. And add virtual environments to global.
  
    pyenvx uninstall package1 [package2 ...]
        Uninstall the specified package(s) by deleting their respective
        virtual environments. And remove virtual environments from global.
  
    pyenvx virtualenvs
        Show a list of all virtual environments managed by this script.
  
    pyenvx [--help, -h]
        Display this help message.

Examples:
    pyenvx install pdm poetry
    pyenvx update pdm
    pyenvx uninstall pdm
    pyenvx virtualenvs

Notes:
    - A virtual environment for each package will be created with
      a 'pyenvx-' prefix.

More information: https://github.com/afaikiac/pyenvx

For instance, if you would like to add system Python and all pyenvx virtual environments to the global, use the following command:

pyenv global system $(pyenvx virtualenvs)

To update all packages installed by this script, you can use the following command:

pyenvx update $(pyenvx virtualenvs | sed 's/^pyenvx-//g')

Configuration

To make use of CLI tools more convenient, you can add the pyenv shims folder to your $PATH:

export PATH="$(pyenv root)/shims:$PATH"

Shell completions for CLI tools can be added manually, depending on your preferred shell.

If you prefer packages to follow the XDG standard, you can configure your ~/.profile as follows:

export XDG_DATA_HOME="$HOME/.local/share"

if command -v pyenv &>/dev/null; then
  export PYENV_ROOT="$XDG_DATA_HOME/pyenv"
  export PATH=$PYENV_ROOT/shims:$PATH
fi

To remove all locally installed packages via pip, you can use this small hack:

pip freeze | awk -v FS='==' '{print $1}' | xargs pip uninstall --yes

And start enjoying the convenience of managing your packages with pyenv!