当我运行 pip freeze
时,我看到(在其他预期的包中)pkg-resources==0.0.0
。我看到一些帖子提到了这个包(包括 this one),但没有人解释它是什么,或者为什么它包含在 pip freeze
的输出中。我想知道的主要原因是出于好奇,但在某些情况下,当尝试使用包含 pkg-resources==0.0.0
行的 pip freeze
生成的 requirements.txt
文件安装软件包时(例如,当 { 2} 尝试通过 pip
安装依赖项并找到此行)。
什么是 pkg-resources
,是否可以从 requirements.txt
中删除这一行?
更新:
我发现当我在 virtualenv
中时,这条线似乎只存在于 pip freeze
的输出中。我仍然不确定它是什么或它做了什么,但我会进一步调查,知道它可能与 virtualenv
有关。
pip
是什么版本?我想这可能是他们在旧版本中遗漏的东西,因为在 8.1.2
我没有 pkg-resources
的条目。 (这不应该,因为我很确定 pkg-resources
与 setuptools
一起提供)。
virtualenv
有关,实际上,当我 not 在 virtualenv 中时,我也看不到它。这仍然无法解释它是什么,但至少是我可以调查的线索。
根据 https://github.com/pypa/pip/issues/4022,这是由于 Ubuntu 向 pip 提供了不正确的元数据而导致的错误。所以,不,这种行为似乎没有充分的理由。我向 Ubuntu 提交了一个后续错误。 https://bugs.launchpad.net/ubuntu/+source/python-pip/+bug/1635463
要备份之前的答案,从您的 requirements.txt 中删除该行应该是安全的。这是一个示例 Make 文件节,它可以安全地冻结您的包列表(放入您的 Makefile 并使用 make freeze
运行):
freeze:
pip freeze | grep -v "pkg-resources" > requirements.txt
编辑 2022 年 7 月 6 日:
我被告知,软件包名称因使用的系统而异(pkg-resources
与 pkg_resources
)。请参阅此答案所附的评论,了解不同版本的 Debian/Ubuntu 之间的使用差异。由于 pkg-resources
是相关系统发布时(大约 6 年前)历史上正确的软件包名称,因此在此答案中将保持不变。
至于你的问题“删除这条线可以吗?”:
我在 ubuntu 16.04 上开发时遇到了同样的问题,要求就是这样。在运行 "pip install -r requirements.txt"
的 debian 8.5 上部署时,pip 抱怨 pkg-resources “未找到”,但安装了一个全局包“python-pkg-resources”,因此应该满足依赖关系。在 ubuntu 上也是如此:该软件包也存在于那里。
如here所述,它似乎是一些“隐式安装的软件包”。
所以:如果你在安装了 python-pkg-resources 的 Debian/Ubuntu 上,删除该行应该是安全的。我这样做了,一切都运行良好。但是,由于我不是这方面的专家,因此您应该记住,在另一台机器上部署时这可能会导致复杂化。
virtualenv
?
在此链接中找到此答案:https://bugs.launchpad.net/ubuntu/+source/python-pip/+bug/1635463
作者:Louis Bouchard (路易斯) 在 2019-11-16 上写道:
它对我有用。但我ḿ不是专家,所以如果有人更好地理解它,如果解释它会很棒。
你好,
对于它的价值,问题来自 virtualenv 的 debianized 版本,它使用了 pkg_resource 的解绑版本,它在创建时添加到 virtualenv 中:
$ virtualenv .
Running virtualenv with interpreter /usr/bin/python2
New python executable in /home/caribou/git/quividi/test/bin/python2
Also creating executable in /home/caribou/git/quividi/test/bin/python
Installing setuptools, pkg_resources, pip, wheel...done.
$ pip freeze
pkg-resources==0.0.0
使用 pip 安装的 virtualenv 版本可能是一种可行的解决方法:
$ sudo apt -y purge python3-virtualenv virtualenv tox
$ pip install virtualenv
$ virtualenv .
pip install virtualenv
Collecting virtualenv
Downloading https://files.pythonhosted.org/packages/c5/97/00dd42a0fc41e9016b23f07ec7f657f636cb672fad9cf72b80f8f65c6a46/virtualenv-16.7.7-py2.py3-none-any.whl (3.4MB)
100% |████████████████████████████████| 3.4MB 351kB/s
Installing collected packages: virtualenv
Successfully installed virtualenv-16.7.7
$ virtualenv .
New python executable in /home/caribou/git/quividi/test/bin/python
Installing setuptools, pip, wheel...
done.
$ source bin/activate
$ pip freeze
$