# pyenv-win-venv **Repository Path**: tb107/pyenv-win-venv ## Basic Information - **Project Name**: pyenv-win-venv - **Description**: No description available - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-01-07 - **Last Updated**: 2025-01-07 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README

pyenv-win-venv

[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/arzkar) A CLI to manage virtual envs with pyenv-win
To report issues for the CLI, open an issue at https://github.com/pyenv-win/pyenv-win-venv/issues # Installation ## Dependencies This script depends on the [pyenv-win](https://github.com/pyenv-win/pyenv-win) so it needs to be installed system to run this script. ## Power Shell ```pwsh Invoke-WebRequest -UseBasicParsing -Uri "https://raw.githubusercontent.com/pyenv-win/pyenv-win-venv/main/bin/install-pyenv-win-venv.ps1" -OutFile "$HOME\install-pyenv-win-venv.ps1"; &"$HOME\install-pyenv-win-venv.ps1" ``` **Note:** Skip the [Add System Settings](#add-system-settings) Section ## Git ```pwsh git clone https://github.com/pyenv-win/pyenv-win-venv "$HOME\.pyenv-win-venv" ``` You need to add the `\bin` path to your environment variables using the following steps. ### Add System Settings Adding the following paths to your USER PATH variable in order to access the pyenv-win-venv command ```pwsh [System.Environment]::SetEnvironmentVariable('path', $env:USERPROFILE + "\.pyenv-win-venv\bin;" + [System.Environment]::GetEnvironmentVariable('path', "User"),"User") ``` - **NOTES**: If you use another path other than `$HOME`, then add the project's `bin` folder to your corresponding USER PATH variable. - For example, your `pyenv-win-venv` folder located in `D:\Applications\pyenv-win-venv` ```pwsh [System.Environment]::SetEnvironmentVariable('path', "D:\Applications\pyenv-win-venv\bin;" + [System.Environment]::GetEnvironmentVariable('path', "User"), "User") ``` # Update Automatically using `pyenv-venv update self` (Recommended) ## Git (If the CLI was installed using Git) Using `git pull`: Go to `%USERPROFILE%\.pyenv-win-venv` (which is your installed path) and run `git pull` ## Power Shell (If the CLI was installed using the PowerScript Installation Script) ```pwsh Invoke-WebRequest -UseBasicParsing -Uri "https://raw.githubusercontent.com/pyenv-win/pyenv-win-venv/main/bin/install-pyenv-win-venv.ps1" -OutFile "$HOME\install-pyenv-win-venv.ps1"; &"$HOME\install-pyenv-win-venv.ps1" ``` # Uninstallation ## CLI ``` pyenv-venv uninstall self ``` ## Power Shell ```pwsh Invoke-WebRequest -UseBasicParsing -Uri "https://raw.githubusercontent.com/pyenv-win/pyenv-win-venv/main/bin/install-pyenv-win-venv.ps1" -OutFile "$HOME\install-pyenv-win-venv.ps1"; &"$HOME\install-pyenv-win-venv.ps1" -Uninstall ``` # Usage ``` > pyenv-win-venv pyenv-win-venv v0.6 Copyright (c) Arbaaz Laskar Usage: pyenv-win-venv A CLI to manage virtual envs with pyenv-win Commands: init search for .python-version file in the current directory and activate the env activate activate an env deactivate deactivate an env completion autocomplete script for powershell install install an env uninstall uninstall an env uninstall self uninstall the CLI and its envs list list all installed envs/python versions local set the given env in .python-version file config show the app directory update self update the CLI to the latest version which show the full path to an executable help show the CLI/ menu Flags: debug To show debug log ``` **Note:** `pyenv-venv` is an alias for `pyenv-win-venv` so either one can be used to call the CLI. # Example - To install an env using Python v3.8.5 (should be already installed in the system using `pyenv install 3.8.5`) ``` pyenv-venv install 3.8.5 env_name ``` - To uninstall an env ``` pyenv-venv uninstall env_name ``` - To activate an env ``` pyenv-venv activate env_name ``` - To deactivate an env ``` pyenv-venv deactivate ``` - To list all installed envs ``` pyenv-venv list envs ``` - To list all installed python versions ``` pyenv-venv list python ``` - To set an env to the `.python-version` file ``` pyenv-venv local env_name ``` - To show the app directory ``` pyenv-venv config ``` - To update the CLI to the latest version ``` pyenv-venv update self ``` - To show the full path to the executable ``` pyenv-venv which ``` - To get help for each command ``` pyenv-venv help install ``` ## PowerShell Completion - To load completion code into current shell: ```pwsh pyenv-venv completion | Out-String | Invoke-Expression ``` - To add completion code directly to the `$PROFILE` ```pwsh pyenv-venv completion >> $PROFILE ``` - One-time execution of `pyenv-venv` completion code to the `$PROFILE` ```pwsh Add-Content $PROFILE "if (Get-Command pyenv-venv -ErrorAction SilentlyContinue) { pyenv-venv completion | Out-String | Invoke-Expression }" ``` - You can also save the completion script and execute it in the `$PROFILE`, for example: ```pwsh # Create completion script pyenv-venv completion > "$HOME\pyenv-venv-completion.ps1" # Add to the `$PROFILE` Add-Content $PROFILE "$HOME\pyenv-venv-completion.ps1" ``` # Note ## Env automatic activation using `.python-version` file - You can set the env for a directory using a `.python-version` file and the CLI can automatically activate the env if a shell is opened in that directory. - `.python-version` file: It should only contain the name of the env and can be created by manually or by using the command: `pyenv-venv local env_name` - You can manually activate the env if the directory has a `.python-version` file by calling `pyenv-venv init` - To enable the automatic feature, you need to add `pyenv-venv init` to your the PowerShell Profile. Steps to do this: - First check if you already have a powershell profile. ```pwsh Test-Path $profile ``` If its `False`, then you need to create a new profile. - Create a new profile using: ```pwsh New-Item -path $profile -type file –force ``` The location to the profile will be shown on the shell. - Open the `profile.ps1` file and append the following line. ``` pyenv-venv init ``` Save and restart the shell. **Note:** If you want the CLI to search for a `.python-version` file by traversing from the current working directory to the root till it finds the file, use `pyenv-venv init root`