5

我刚刚开始使用 Python,需要一些指导。

我使用的是 Mac,但我安装了 python.org 构建的 python 以及原始的 Apple 安装。

我正在尝试加载一些第 3 方模块。当我在 IDLE 中或通过终端运行脚本时,一切正常。当我尝试将它作为 CRON 作业运行时,我收到一条错误消息,指出它找不到 3rd 方模块。

经过一番摸索,我一直相信它是 PYTHONPATH / sys.path。我创建了一个测试脚本来向我展示我的路径。那么,为什么当它通过终端窗口运行而不是直接作为 shell 脚本运行时,我会得到不同的路径呢?

我的两个问题是:

  1. 为什么它们不同?
  2. 如何获得直接 shell 进程来查找第 3 方模块?

这是我在终端中运行时的 sys.path 输出:

['/Library/Scripts',
 '/Library/Scripts/$',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python27.zip',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/plat-darwin',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/plat-mac',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/plat-mac/lib-scriptpackages',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/lib-tk',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/lib-old',
 '/Library/Frameworks/Python.framework/Versions/7.3/lib/python2.7/lib-dynload',
 '/Library/Python/2.7/site-packages']

这是我在 shell 中运行时的 sys.path 输出(在这种情况下,我在 Applescript 中使用“执行 shell 脚本”步骤。

"['/Library/Scripts',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python27.zip',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-darwin',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac/lib-scriptpackages',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-tk',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-old',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-dynload',
 '/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python/PyObjC',
 '/Library/Python/2.7/site-packages']"
4

1 回答 1

4

为什么它们不同?

因为您正在运行两个不同的 Python 解释器,并且它们具有不同的默认sys.path值。

这是故意的——它允许您修改 Python.org 安装的标准(或站点)库,而不会破坏系统安装(或依赖于该安装的任何 Apple 提供的工具)。

我猜当你python在终端中运行时,你会得到/usr/local/bin/python(你可以通过键入来检查which python),这可能是一个链接/Library/Frameworks/Python.framework/Versions/7.3/bin/python(或者可能是Python.app/Contents/MacOS/python该框架内的某个地方)。来自 python.org 的 Python 被编译为sys.path围绕 /Library/Frameworks/Python.framework/Versions/7.3/ 设置。

同时,当您python通过 Launch Services 运行时,您可能会得到/usr/bin/python,这是(希望)内置的 shim around /System/Library/Frameworks/Python.framework/Versions/2.7/bin/python,它被编译为设置sys.patharound /System/Library/Frameworks/Python.framework/Versions/2.7/

python在这些情况下做不同事情的原因/usr/local/bin是根本不在您的登录中,而是通过您(或其他)文件PATH中的一行添加到路径的头部。~/.profile该文件由终端中的 shell 会话读取,但不是由启动服务会话读取。

如果您想在所有环境中使用相同的 Python,您可以显式运行/usr/local/bin/python/usr/bin/python而不是仅python. (您也可以/usr/local/bin进入您的登录路径,但这是一个非常糟糕的主意,或者将其从您的 PATH 中取出~/.profile,但这有点不方便。)

附带说明一下,这表明您的 python.org 安装非常损坏:

/Library/Frameworks/Python.framework/Versions/7.3/lib/python27.zip

没有 Python 7.3。我强烈考虑卸载并重新安装 python.org 构建。

或者,更简单地说,卸载它并保持卸载状态,只使用内置的 Python 2.7。如果您想要多个环境,请使用virtualenv而不是多个安装。例如,如果 Apple 给你 2.7.2 而你真的需要 2.7.3,那么你需要另一个安装;否则,你只会让事情变得更难,没有任何好处。

于 2012-10-23T00:33:05.180 回答