在 PEX 中使用 python 脚本执行时出现 pyyaml 依赖错误
pyyaml dependency error while executing with python script in PEX
我在尝试使用 PEX 打包和执行脚本时遇到以下错误。
Failed to execute PEX file. Needed macosx_10_14_x86_64-cp-38-cp38 compatible dependencies for:
1: pyyaml
Required by:
app==0.0.1
But this pex only contains:
PyYAML-5.3.1-cp39-cp39-macosx_10_14_x86_64.whl
这是我打包文件的方式:
执行以下命令生成 zip 文件
pex requests 'XlsxWriter==1.3.7' 'urllib3==1.26.2' 'PyYAML==5.3.1' ./app -o app.pex --python-shebang '#!/usr/bin/env python3'
使用调试日志执行时,我看到以下错误
(base)$ PEX_VERBOSE=9 ./app.pex
pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Resolving pyyaml from [Requirement.parse('PyYAML==5.3.1; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_version pex: Failed to resolve a requirement: The 'pyyaml' distribution was not found and is required by the application
pex: Failed to resolve a requirement: The 'PyYAML' distribution was not found and is required by app
pex: Activating
PEX virtual environment from ./app.pex :: Resolving chardet from [Requirement.parse('chardet==4.0.0; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_versiopex: Activating
PEX virtual environment from ./app.pex :: Resolving idna from [Requirement.parse('idna==2.10; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_version != "3pex: Activating
PEX virtual environment from ./app.pex :: Resolving requests from [Requirement.parse('requests==2.25.1; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_verpex: Activating
PEX virtual environment from ./app.pex :: Resolving urllib3 from [Requirement.parse('urllib3==1.26.2; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_versipex: Unresolved requirements:
环境:
$ python --version
Python 2.7.16
$ python3 --version
Python 3.9.1
$ python2 --version
bash: python2: command not found
$ pip --version
bash: /usr/local/bin/pip: /usr/local/opt/python@3.8/bin/python3.8: bad interpreter: No such file or directory
$ pex --version
2.1.24
$ whereis python
/usr/bin/python
据我从您的环境数据中可以看出,您必须安装 python3.8,然后执行:
python3.8 -m pip install pyyaml
您可能首先在您的计算机上安装了 python3.8,然后用 python3.8 安装了 pex,然后卸载了 python3.8。所以,现在只剩下 python3.9,但是 pex 仍然配置为使用 python3.8。而 pex 现在寻找 python3.8 的 pyyaml,但只找到 python3.9 的 pyyaml。另一种解决方案是卸载您现在拥有的 pex,然后使用以下命令重新安装它:
python3.9 -m pip install pex
我通过将 env 更改为 3.9 解决了这个问题
pex requests 'XlsxWriter==1.3.7' 'urllib3==1.26.2' 'PyYAML==5.3.1' ./app -o app.pex --python-shebang '#!/usr/bin/env python3.9'
我在尝试使用 PEX 打包和执行脚本时遇到以下错误。
Failed to execute PEX file. Needed macosx_10_14_x86_64-cp-38-cp38 compatible dependencies for:
1: pyyaml
Required by:
app==0.0.1
But this pex only contains:
PyYAML-5.3.1-cp39-cp39-macosx_10_14_x86_64.whl
这是我打包文件的方式:
执行以下命令生成 zip 文件
pex requests 'XlsxWriter==1.3.7' 'urllib3==1.26.2' 'PyYAML==5.3.1' ./app -o app.pex --python-shebang '#!/usr/bin/env python3'
使用调试日志执行时,我看到以下错误
(base)$ PEX_VERBOSE=9 ./app.pex
pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Searching dependency cache: /Users[PATH]/app.pex/pex: Activating
PEX virtual environment from ./app.pex :: Resolving pyyaml from [Requirement.parse('PyYAML==5.3.1; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_version pex: Failed to resolve a requirement: The 'pyyaml' distribution was not found and is required by the application
pex: Failed to resolve a requirement: The 'PyYAML' distribution was not found and is required by app
pex: Activating
PEX virtual environment from ./app.pex :: Resolving chardet from [Requirement.parse('chardet==4.0.0; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_versiopex: Activating
PEX virtual environment from ./app.pex :: Resolving idna from [Requirement.parse('idna==2.10; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_version != "3pex: Activating
PEX virtual environment from ./app.pex :: Resolving requests from [Requirement.parse('requests==2.25.1; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_verpex: Activating
PEX virtual environment from ./app.pex :: Resolving urllib3 from [Requirement.parse('urllib3==1.26.2; python_full_version != "3.0.*" and python_full_version != "3.1.*" and python_full_versipex: Unresolved requirements:
环境:
$ python --version
Python 2.7.16
$ python3 --version
Python 3.9.1
$ python2 --version
bash: python2: command not found
$ pip --version
bash: /usr/local/bin/pip: /usr/local/opt/python@3.8/bin/python3.8: bad interpreter: No such file or directory
$ pex --version
2.1.24
$ whereis python
/usr/bin/python
据我从您的环境数据中可以看出,您必须安装 python3.8,然后执行:
python3.8 -m pip install pyyaml
您可能首先在您的计算机上安装了 python3.8,然后用 python3.8 安装了 pex,然后卸载了 python3.8。所以,现在只剩下 python3.9,但是 pex 仍然配置为使用 python3.8。而 pex 现在寻找 python3.8 的 pyyaml,但只找到 python3.9 的 pyyaml。另一种解决方案是卸载您现在拥有的 pex,然后使用以下命令重新安装它:
python3.9 -m pip install pex
我通过将 env 更改为 3.9 解决了这个问题
pex requests 'XlsxWriter==1.3.7' 'urllib3==1.26.2' 'PyYAML==5.3.1' ./app -o app.pex --python-shebang '#!/usr/bin/env python3.9'