文章目录
-
-
- [Using the py.exe Launcher](#Using the py.exe Launcher)
-
- [Installation and Setup](#Installation and Setup)
- [Basic Usage](#Basic Usage)
- [Using pyenv-win](#Using pyenv-win)
-
- Installation
- [Basic Usage](#Basic Usage)
- Tips
- [Other Considerations](#Other Considerations)
-
Managing multiple Python versions on Windows can be done through a few reliable methods, depending on your needs for simplicity, flexibility, or project isolation. I'll cover the two most popular approaches: the built-in py.exe launcher (which comes with Python 3 installations) and pyenv-win (a port of the Unix pyenv tool). These allow you to install, switch, and run different versions without conflicts. For project-specific isolation, combine these with Python's built-in venv module to create virtual environments tied to specific versions.
Using the py.exe Launcher
The py.exe launcher is a lightweight tool included with Python 3 installations on Windows. It helps discover installed Python versions, select specific ones for execution, and handle scripts with shebang lines. It's ideal if you just need to run different versions without advanced management.
Installation and Setup
- When installing Python from the official website (python.org), ensure you select the option to install the launcher during setup. It's optional, so check the box for "py launcher" or similar.
- If it's not installed, reinstall Python and enable it. The launcher will be added to your PATH automatically.
- For older versions like Python 2.7, you may need to manually add registry keys for detection (under
HKEY_LOCAL_MACHINE\Software\Python\PythonCoreor user-specific equivalents) if they're missing.
Basic Usage
-
List installed Python versions : Run
py -0to see all detected versions and architectures (e.g.,-3.9-64 *indicates the default). Usepy -0pto include full paths topython.exe. -
Run a specific version : Use flags like
py -3.8to run Python 3.8, orpy -2for the latest Python 2.x. For example:py -3.8 --versionThis outputs the version info for Python 3.8.
-
Run scripts : Execute a script with a specific version, e.g.,
py -3.7 myscript.py. If your script has a shebang (e.g.,#!/usr/bin/env python3), runningpy myscript.pywill automatically use the matching version. -
Default behavior : Without flags,
pyuses the latest installed version. To check:py --version.
This method doesn't handle installing new versions---you'll need to download and install them manually from python.org---but it's great for switching between existing ones.
Using pyenv-win
For more comprehensive management, including easy installation and switching of versions, use pyenv-win. It's a Windows-specific tool that mirrors the Unix pyenv and lets you install, list, set global/local versions, and uninstall Pythons without affecting your system PATH.
Installation
-
Open PowerShell (run as administrator if needed).
-
Download and run the installation script:
Invoke-WebRequest -UseBasicParsing -Uri "https://raw.githubusercontent.com/pyenv-win/pyenv-win/master/pyenv-win/install-pyenv-win.ps1" -OutFile "./install-pyenv-win.ps1"; &"./install-pyenv-win.ps1"- If you get an execution policy error, run
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope LocalMachinefirst.
- If you get an execution policy error, run
-
Reopen PowerShell.
-
Verify with
pyenv --version. -
Update the version database:
pyenv update. -
(Optional but recommended for Windows 10+): Disable built-in Python app aliases in Settings > Apps > Apps & features > App execution aliases, and turn off Python-related ones.
-
Add these to your system PATH (via System Properties > Environment Variables) if not added automatically:
C:\Users\<YourUsername>\.pyenv\pyenv-win\binC:\Users\<YourUsername>\.pyenv\pyenv-win\shims
-
Restart your terminal or IDE.
Basic Usage
- List available versions to install :
pyenv install --list(orpyenv install -l). Filter withpyenv install -l | findstr 3.8for specific ones. - Install a version :
pyenv install <version>, e.g.,pyenv install 3.13.5. For multiple:pyenv install 3.13.5 3.14.0. Use-qfor quiet mode (no prompts).- Supports 32-bit with suffixes like
3.8.2-win32.
- Supports 32-bit with suffixes like
- List installed versions :
pyenv versions. - Check current version :
pyenv version. - Set versions :
- Global (system-wide):
pyenv global <version>, e.g.,pyenv global 3.13.5. Usepyenv global systemto revert to your system's default Python. - Local (project directory):
pyenv local <version>. This creates a.python-versionfile in the folder for automatic switching. - Shell (current session):
pyenv shell <version>. Unset withpyenv shell --unset.
- Global (system-wide):
- Uninstall a version :
pyenv uninstall <version>. - Rehash shims : After installing packages or switching versions, run
pyenv rehashto update executable paths. - Run commands with a version :
pyenv exec python myscript.pyuses the current version's Python.
Tips
- Always run
pyenv rehashafter changes to ensure tools likepipwork correctly. - For project isolation, after setting a version, create a virtual environment:
python -m venv myenv, then activate it. - pyenv-win builds versions from source, so installations can take time but support a wide range (Python 2.4+).
Other Considerations
- Manual Management : Install versions from python.org into separate directories (e.g.,
C:\Python38), then call them explicitly likeC:\Python38\python.exe myscript.pyor adjust PATH temporarily. This is basic but error-prone for frequent switches. - Anaconda/Miniconda : If you work with data science, use Miniconda to install different Python versions via environments (e.g.,
conda create -n py38 python=3.8). It's heavier but includes package management. - Best Practices: Avoid modifying your system PATH globally for Pythons to prevent conflicts. Test versions in isolated environments, and keep your default system Python untouched for OS compatibility.
If you run into issues, check your environment variables or restart your terminal. For the latest updates, refer to the official pyenv-win repo or Python docs.