You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
venv on Windows 11 with Python 3.13.7 includes global paths in sys.path despite include-system-site-packages = false, causing packages to be installed globally instead of in the venv #138691
When creating and activating a virtual environment with Python 3.13.7 on Windows 11, sys.path includes global Python paths (e.g., C:\Program Files\Python313\python313.zip, C:\Program Files\Python313\DLLs, etc.), even though pyvenv.cfg has include-system-site-packages = false. This causes python -m pip install <package> to install packages to the global site-packages (C:\Program Files\Python313\Lib\site-packages) instead of the virtual environment's site-packages.
This breaks virtual environment isolation, requiring --target for every install, which is not the expected behavior.
Steps to Reproduce
Install Python 3.13.7 from the official Windows installer, ensuring "Add python.exe to PATH" is checked.
Open PowerShell 7.5.2.
Create a test directory and virtual environment:
mkdir test_venv_bug
cd test_venv_bug
python -m venv .venv
Activate the virtual environment:
..venv\Scripts\Activate.ps1
python -m pip install requests installs to global site-packages (C:\Program Files\Python313\Lib\site-packages), with warnings like "Target directory C:\Program Files\Python313\Lib\site-packages\certifi already exists."
python -m pip list in venv shows only pip; packages are missing in venv.
Environment
Python version: 3.13.7 (installed via official Windows installer)
Bug report
Bug description:
Description
When creating and activating a virtual environment with Python 3.13.7 on Windows 11,
sys.pathincludes global Python paths (e.g.,C:\Program Files\Python313\python313.zip,C:\Program Files\Python313\DLLs, etc.), even thoughpyvenv.cfghasinclude-system-site-packages = false. This causespython -m pip install <package>to install packages to the globalsite-packages(C:\Program Files\Python313\Lib\site-packages) instead of the virtual environment'ssite-packages.This breaks virtual environment isolation, requiring
--targetfor every install, which is not the expected behavior.Steps to Reproduce
Install Python 3.13.7 from the official Windows installer, ensuring "Add python.exe to PATH" is checked.
Open PowerShell 7.5.2.
Create a test directory and virtual environment:
mkdir test_venv_bug
cd test_venv_bug
python -m venv .venv
Activate the virtual environment:
..venv\Scripts\Activate.ps1
Check
sys.path:python -c "import sys; print('\n'.join(sys.path))"
Expected: Only venv paths (e.g.,
C:\path\to\test_venv_bug\.venv,C:\path\to\test_venv_bug\.venv\Lib\site-packages).Check
pyvenv.cfg(should haveinclude-system-site-packages = false):Get-Content .venv\pyvenv.cfg
Install a test package:
python -m pip install requests
Verify installation location:
python -m pip list
Get-ChildItem -Path .venv\Lib\site-packages | findstr requests
Get-ChildItem -Path 'C:\Program Files\Python313\Lib\site-packages' | findstr requests
Expected:
requestsin.venv\Lib\site-packages; nothing in global.Expected Behavior
sys.pathshould only include virtual environment paths (no globalC:\Program Files\Python313*paths).python -m pip installshould install to.venv\Lib\site-packages.Actual Behavior
sys.pathincludes global paths:python -m pip install requestsinstalls to globalsite-packages(C:\Program Files\Python313\Lib\site-packages), with warnings like "Target directory C:\Program Files\Python313\Lib\site-packages\certifi already exists."python -m pip listin venv shows onlypip; packages are missing in venv.Environment
pyvenv.cfgcontents:(.venv) PS ...Get-Command pythonandGet-Command pippoint to venvScripts\python.exeandScripts\pip.exe.Additional Notes
--target=.venv\Lib\site-packagesworks as a workaround, but it's cumbersome.Minimal Reproducible Example
See "Steps to Reproduce" above. The test directory can be zipped and attached if needed.
Thanks for looking into this—it's breaking venv isolation on Windows.
CPython versions tested on:
3.13
Operating systems tested on:
Windows