工作答案 - 06-30-2021 @15:43 UTC
我多次查看 faust 存储库,发现aiodns 、 cython和ciso8601本身不是依赖项,而是捆绑包,根据自述文件以这种方式使用 pip 安装:
pip install "faust[aiodns, ciso8601, cython]"
我根据您的要求创建了一个 setup.py。我能够在非 Windows 系统上使用捆绑包aiodns、ciso8601、cython安装faust 。我没有 Windows 系统来测试该安装,但我确实翻转了系统平台参数,这很有效。
import setuptools
setuptools.setup(
name="faust_pip_test", # change for your package
version="1.0.0", # change for your package
python_requires='>=3.6',
install_requires=["faust[aiodns, ciso8601,cython]>=1.10.1;sys_platform != 'win32'",
"faust[aiodns, cython]>=1.10.1;sys_platform == 'win32'",]
)
这是与 faust 一起安装的faust_pip_test包以及我的 MacBook 上的附加包aiodns、ciso8601和cython。
在查看了不直观的 PipeEnv 文档后,您似乎可以在 pipfile 中执行以下操作。我查看的每个参考资料都要求您为辅助键指定一个文件路径,这就是faust_win。在faust_win中调用的文件来自faust PyPi downloads。
[packages]
faust = {version = ">=1.10.1",extras = ["aiodns", "ciso8601", "cython"],sys_platform = "!='windows'"}
faust_win = {file = 'https://files.pythonhosted.org/packages/79/f8/3fec4f5c3e5bf1ce8bb557ae507525253fa30a5cfc5984f342b931143f75/faust-1.10.4-py2.py3-none-any.whl',version = ">=1.10.1",extras = ["aiodns", "cython"],sys_platform = "=='windows'"}
我将 PyCharm 用于我的开发环境。__init__.py
如果我在我的项目faust_pipenv_test中创建一个,它会自动触发我的项目的依赖项安装。安装了浮士德 标准依赖项要求以及附加包aiodns、ciso8601和cython。
我还收到一条消息,说没有安装faust_win要求,因为它不符合这个要求sys_platform =='win32'
。
更新 06-28-2021 @12:23 UTC
当我查看faust的源代码时,我注意到包
aiodns、cython和ciso8601是faust的setup.py文件中的依赖项。
因此,根据您的问题,您似乎不想
在非 Windows 系统上安装ciso8601的浮士德默认依赖项。根据附加列表,您似乎也在尝试限制其他依赖项。
这是你想要完成的吗?
Python 开发人员指南指出,“ extras”参数用于安装额外的依赖项,这是对正在安装的Python包的常规依赖项的补充。
参考:PEP 426 -- Python 软件包 2.0 的元数据
下面的代码来自 PipeEnv Python 包,它显示“extras”参数与包的核心依赖项相结合。
def dependencies(self):
# type: () -> Tuple[Dict[S, PackagingRequirement], List[Union[S, PackagingRequirement]], List[S]]
build_deps = [] # type: List[Union[S, PackagingRequirement]]
setup_deps = [] # type: List[S]
deps = {} # type: Dict[S, PackagingRequirement]
if self.setup_info:
setup_info = self.setup_info.as_dict()
deps.update(setup_info.get("requires", {}))
setup_deps.extend(setup_info.get("setup_requires", []))
build_deps.extend(setup_info.get("build_requires", []))
if self.extras and self.setup_info.extras:
for dep in self.extras:
if dep not in self.setup_info.extras:
continue
extras_list = self.setup_info.extras.get(dep, []) # type: ignore
for req_instance in extras_list: # type: ignore
deps[req_instance.key] = req_instance
if self.pyproject_requires:
build_deps.extend(list(self.pyproject_requires))
setup_deps = list(set(setup_deps))
build_deps = list(set(build_deps))
return deps, setup_deps, build_deps
因此下面的示例需要测试,因为在Pipenv 的高级用法文档中没有明确说明您是否可以覆盖第三方 Python 包的依赖项要求。
[packages]
faust = {version= ">=1.10.1", extras=["aiodns", "cython"]}
ciso8601 = {version = ">=2.1.0", sys_platform = "!= 'Windows'", index="pypi"}
or
[packages]
faust = {version=">=1.10.1", extras=["aiodns", "ciso8601", "cython"], sys_platform= "!= 'Windows'"}
"faust_win" = {version=">=1.10.1", extras=["aiodns", "cython"], sys_platform = "== 'Windows'"}
原帖 06-26-2021
TOML 文档中不允许有重复的键。
例如这个:
faust = {version=">=1.10.1", extras=["aiodns", "ciso8601", "cython"], platform_system = "!= 'Windows'"}
faust = {version=">=1.10.1", extras=["aiodns", "cython"], platform_system = "== 'Windows'"}
参考pipenv的源码
# file: /pipenv/vendor/tomlkit/exceptions.py
# which is referenced from here /pipenv/vendor/tomlkit/container.py
class KeyAlreadyPresent(TOMLKitError):
"""
An already present key was used.
"""
def __init__(self, key):
message = 'Key "{}" already exists.'.format(key)
super(KeyAlreadyPresent, self).__init__(message)
此外,重复密钥问题已在TOML Github 存储库中进行了讨论。