我正在使用virtualenv和virtualvwrapper。我可以使用workon命令在virtualenv之间切换。

me@mymachine:~$ workon env1
(env1)me@mymachine:~$ workon env2
(env2)me@mymachine:~$ workon env1
(env1)me@mymachine:~$ 

如何退出所有虚拟环境并再次使用系统环境?现在,我唯一能回到me@mymachine:~$是退出shell并开始新的shell。这有点烦人。是否有命令处理“无”,如果有,是什么?如果不存在这样的命令,我将如何创建它?


当前回答

我发现在Miniconda3环境中,我必须运行:

conda deactivate

去激活和源去激活对我都不起作用。

其他回答

对于我的特定情况,我转到工作目录

CD /myworkingdirectory

然后我像这样激活env:

my-env/scripts/activate

从要停用的同一个工作文件夹(/myworkingdirectory)中,我尝试了此操作,但它无效:

my-env/scripts/deactivate

这确实有效:

deactivate

在我的情况下,我能够使用env-name\scripts\activate激活虚拟环境,并使用deactivate停用它。然而,在我的windows PC上运行更新后,停用不再被识别为内部或外部命令。从那一刻起,我使用的是env-name\scripts\deactivate,这解决了问题。

我发现在Miniconda3环境中,我必须运行:

conda deactivate

去激活和源去激活对我都不起作用。

我定义了一个别名workoff,与workon相反:

alias workoff='deactivate'

很容易记住:

[bobstein@host ~]$ workon django_project
(django_project)[bobstein@host ~]$ workoff
[bobstein@host ~]$

由于在~/bin中查找此类命令的常规方法无法发现通过sourcing ~/bin/activate创建的停用函数,因此您可能希望创建一个只执行函数deactivate的函数。

问题是,一个名为deactivate的脚本包含一个单独的命令deactivate,如果在不在venv中的情况下意外执行,将导致无休止的循环。一个常见的错误。

如果功能存在(即通过源激活创建),则只执行停用即可避免这种情况。

#!/bin/bash

declare -Ff deactivate  && deactivate