我最近在我的Mac上安装了一堆dotfiles和其他一些应用程序(我把Terminal换成了iTerm, Sublime作为我的默认文本编辑器),但从那以后,我所有的虚拟环境都停止了工作,尽管它们的文件夹在.virtualenvs中仍然存在,每当我试图在其中运行任何东西时,它们都会给出以下错误:

dyld: Library not loaded: @executable_path/../.Python
  Referenced from: /Users/[user]/.virtualenvs/modclass/bin/python
  Reason: image not found
Trace/BPT trap: 5

我已经删除了所有与dotfiles相关的文件,并将.bash_profile恢复到以前的状态,但问题仍然存在。有什么方法可以诊断问题或以一种简单的方式解决它(例如,不需要重新创建所有的virtualenv)?


当前回答

接受的答案不适合我:文件$WORKON_HOME/*/bin/python2.7不再是一个符号链接,它是一个成熟的可执行文件:

$ file $WORKON_HOME/*/bin/python2.7
/Users/sds/.virtualenvs/.../bin/python2.7: Mach-O 64-bit executable x86_64
...

解决方案是完全删除并从头重新创建所有虚拟环境。

供参考:

deactivate
pip install --user virtualenv virtualenvwrapper
pip install --user --upgrade virtualenv virtualenvwrapper
for ve in $(lsvirtualenv -b); do
  # assume that each VE is associated with a project
  # and the project has the requirements.txt file
  project=$(cat $WORKON_HOME/$ve/.project)
  rmvirtualenv $ve
  mkvirtualenv -a $project -r requirements.txt $ve
done

其他回答

在我的OSX Catalina上升级brew后,我也面临着同样的问题。

在尝试了很多东西之后,我发现以下是最好的和简单的解决方案。

首先,删除虚拟环境。(可选)

find myvirtualenv -type l -delete

然后重新创建一个新的virtualenv

virtualenv myvirtualenv

参考:https://www.jeremycade.com/python/osx/homebrew/2015/03/02/fixing-virtualenv-after-a-python-upgrade/

如果你用pipenv,用pipenv -rm就能解决问题。

virtualenvwrapper指令

正如已接受的答案所示,根本原因可能是一个自制更新,这意味着您的virtualenv符号链接指向损坏的python路径-请参阅这里的详细信息。

对于每个虚拟env,您需要重新分配符号链接以指向正确的python路径(在酿造窖中)。下面是如何使用virtualenvwrapper来做到这一点。这里我正在更新一个名为“my-example-env”的虚拟环境。

cd ~/PYTHON_ENVS
find ./my-example-env -type l -delete
mkvirtualenv my-example-env

全部完成。

当我在mac上将python运行时从2指向3时,我遇到了同样的问题,将别名python指向python 3路径。然后,我重新创建一个新的virtualenv并重新安装我的项目所需的那些包。对于我的用例,我有一个python程序写入谷歌表。清理了一些不同于python2实现的包,事情又开始工作了。

我肯定我来晚了,但我想说的是,这个问题的解决办法比这里讨论的要简单得多。

您可以轻松地重新生成虚拟环境,而无需删除/编辑任何内容。假设你的坏环境被称为env_to_fix,你可以执行以下命令:

mkvirtualenv env_to_fix

这将重新生成链接并修复环境,而不需要将当前状态转储到某个地方并恢复它。