在 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'