1

我有一个要在 PyPI 上发布的 Python 库 ( https://github.com/jcrozum/PyStableMotifs )。它依赖于我无法控制的另一个库(https://github.com/hklarner/PyBoolNet),该库仅在 GitHub 上可用,特别是在 PyPI 上不可用。我的 setup.py 看起来像这样:

from setuptools import
setup(
    ... <other metadata> ...,
    install_requires=[
    'PyBoolNet @ git+https://github.com/hklarner/PyBoolNet@2.3.0',
    ... <other packages> ...
    ]
)

运行pip install git+https://github.com/jcrozum/PyStableMotifs完美,但由于 twine 的以下错误,我无法将其上传到 PyPI:

Invalid value for requires_dist. Error: Can't have direct dependency: 'PyBoolNet @ git+https://github.com/hklarner/PyBoolNet@2.3.0'

我的理解是,出于安全原因,PyPI 禁止直接链接。尽管如此,PyBoolNet 是 PyStableMotifs 的硬性要求。我该怎么办?放弃 PyPI?

我只想pip install PyStableMotifs为我的用户工作。理想情况下,这个命令应该安装依赖项,我不应该维护两个版本的 setup.py。

如果做不到这一点,我考虑在 PyPI 上创建一个“虚拟”包,指导用户使用命令进行安装pip install git+https://github.com/jcrozum/PyStableMotifs。这是一个坏主意(甚至可能)?

是否已经建立了针对这种情况的最佳实践或其他常见的解决方法?

编辑:目前,我有一个笨重且完全不令人满意的解决方法。我保留了两个版本;一个完美运行的 GitHub 版本,以及一个删除了 PyBoolNet 要求的 PyPI 版本。如果用户尝试在未安装 PyBoolNet 的情况下导入 PyStableMotifs,则会显示一条错误消息,其中包含 PyBoolNet 的安装说明。在我看来,这远非理想,但在我找到更好的解决方案或 PyPI 修复此错误(或删除此功能,取决于你问谁)之前,它必须这样做。

4

1 回答 1

2

我的建议是去掉 中的直接 URL install_requires,并告诉您的用户他们可以在哪里找到该依赖项 PyBoolNet,因为它不在PyPI上。不要强迫他们使用特定的安装方法,而是向他们展示一个示例。

也许只是告诉你的用户这样的事情:

这个项目依赖于PyBoolNet ,它在PyPI上不可用。您可以找到它的一个地方是:https://github.com/hklarner/PyBoolNet.

安装PyStableMotifs及其依赖项 PyBoolNet的一种方法是运行以下命令:

python -m pip install 'git+https://github.com/hklarner/PyBoolNet@2.3.0#egg=PyBoolNet' PyStableMotifs

您还可以准备一个requirements.txt文件并告诉您的用户:

使用以下命令安装:

python -m pip install --requirement https://raw.githubusercontent.com/jcrozum/PyStableMotifs/master/requirements.txt

的内容requirements.txt可能类似于:

git+https://github.com/hklarner/PyBoolNet@2.3.0#egg=PyBoolNet
PyStableMotifs

但最后,您应该真正让您的用户选择如何安装该依赖项。您的项目只需要声明它依赖于该库,而不需要声明如何安装它。

于 2021-06-22T17:57:44.153 回答