我最近在我的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)?


当前回答

在尝试了一些事情之后,这对我来说很有效:

进入你的virtualenv目录(但不要运行workon):

cd ~/.virtualenv/name_of_broken_venv

现在删除这些文件:

rm -rf .Python bin/python* lib/python2.7/* include/python2.7

然后重新构建venv,运行:

virtualenv .
workon name_of_broken_venv
pip freeze

现在您应该再次看到已安装包的列表。

其他回答

使用Python 2.7.10。

一个命令virtualenv path-to-env就可以做到这一点。文档

$ virtualenv path-to-env
Overwriting path-to-env/lib/python2.7/orig-prefix.txt with new content
New python executable in path-to-env/bin/python2.7
Also creating executable in path-to-env/bin/python
Installing setuptools, pip, wheel...done.

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

virtualenvwrapper指令

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

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

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

全部完成。

我在这里找到了这个问题的解决方案,所以所有的功劳都归于作者。

要点是,当您创建virtualenv时,会创建许多到已安装的Homebrew Python的符号链接。

这里有一个例子:

$ ls -la ~/.virtualenvs/my-virtual-env
...
lrwxr-xr-x  1 ryan staff   78 Jun 25 13:21 .Python -> /usr/local/Cellar/python/2.7.7/Frameworks/Python.framework/Versions/2.7/Python
...

当您使用Homebrew升级Python并运行brew cleanup时,virtualenv中的符号链接指向不再存在的路径(因为Homebrew删除了它们)。

符号链接需要指向新安装的Python:

lrwxr-xr-x  1 ryan staff   78 Jun 25 13:21 .Python -> /usr/local/Cellar/python/2.7.8_1/Frameworks/Python.framework/Versions/2.7/Python

解决方案是删除virtualenv中的符号链接,然后重新创建它们:

find ~/.virtualenvs/my-virtual-env/ -type l -delete
virtualenv ~/.virtualenvs/my-virtual-env

在删除链接之前,最好先检查哪些链接将被删除:

find ~/.virtualenvs/my-virtual-env/ -type l

在我看来,只删除损坏的符号链接更好。你可以使用GNU find:

gfind ~/.virtualenvs/my-virtual-env/ -type l -xtype l -delete

如果你还没有,你可以在Homebrew中安装GNU find:

brew install findutils

注意,默认情况下,安装Homebrew的GNU程序倾向于以字母g作为前缀。这是为了避免遮蔽OS X附带的find二进制文件。

virtualenv被破坏了。有时简单的方法是删除venv文件夹并重新创建virutalenv。