python安装虚拟环境没有activate_Python venv虚拟环境:Activate命令的作用

之前在处理其它需求时,发现只要用venv目录下的python.exe来解释py代码就可以正常运行。本来以为完事了,突然想起来,这样的话根本没有运行Activate命令,没有进入Python虚拟环境啊。于是稍微研究了一下这个问题。

[Activate]

看了下Activate源码,其中最重要的动作是把venv虚拟环境的路径临时添加到系统Path路径最前面,这样venv的pip命令就能把模块(库)安装到虚拟环境目录里。Path配置的信息可以在PowerShell里,通过 $env:Path 命令查看,能够清楚的看到运行Activate之后venv目录添加到了Path配置的最前面。

PowerShell中,通过 $env:Path 指令查看Path信息

运行Activate之后虚拟目录添加到了Path配置的最前面

[是否Activate进入虚拟环境对pip的影响]

写一个py测试文件,引入os模块(库),然后执行 os.system("pip list")

Activate进入虚拟环境,执行,列出venv中已经添加的模块;用系统Python执行,列出系统Python中已经添加的模块。

不Activate虚拟环境,直接用venv目录里的python.exe执行,列出系统Python中添加的模块

也就是说不Activate进入虚拟环境,会调用系统Python的pip命令

[是否Activate虚拟环境对Python.exe执行py代码有什么区别]

再编写py文件,引入sys模块(库),打印Python相关的环境变量print(sys.path)

系统Python执行

首先用系统Python执行:

路径中包括 [当前源码目录、系统Python的dll和lib目录,以及系统Python的site-packages目录]

Activate进入虚拟环境并执行

Activate进入虚拟环境并执行:

结果包括 [当前源码目录、系统Python的dll和lib目录,venv目录、venv的site-packages目录]

直接用venv目录里的python.exe执行

不Activate虚拟环境,直接用venv目录里的python.exe执行:

结果包括 [当前源码目录、系统Python的dll和lib目录,venv目录、venv的site-packages目录]

是否运行Activate都不影响最终结果

[结论]

无论是否Activate,虚拟环境的python.exe在运行时,环境变量自动包含venv的site-packages目录。

所以用venv的python.exe执行py代码,跟是否Activate虚拟环境没有关系。

Activate影响的是pip安装模块(库)的时候。

同时也清楚了venv里的Python还是继承系统Python的DLL和Lib,所以直接把venv拷贝给其它机器的话,至少需要对方机器里已经安装了同版本的Python。

相关视频:

你可能感兴趣的:(python安装虚拟环境没有activate_Python venv虚拟环境:Activate命令的作用)