【问题标题】:launchd executes python script, but import failslaunchd 执行 python 脚本,但导入失败
【发布时间】:2011-04-06 22:04:38
【问题描述】:

我使用 appscript 编写了一个 python 脚本来跟踪我当前活动的窗口。我通过launchd运行它,但是当我这样做时它无法导入appscript。我已经在plist 中为launchd 设置了PYTHONPATH,但我认为launchd 没有读取站点包中的.pth 文件。有没有办法让它做到这一点?

我的脚本在这里:https://github.com/katylava/macwintracker

这是已启动的 plist:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
  <dict>
    <key>label</key>
    <string>com.katylavallee.wintracker</string>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py</string>
        <string>1</string>
        <string>1</string>
    </array>
    <key>Environment Variables</key>
    <dict>
      <key>PYTHONPATH</key>
      <string>/opt/local/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages</string>
    </dict>
    <key>StandardErrorPath</key>
    <string>/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker_err.log</string>
    <key>StandardOutPath</key>
    <string>/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker.log</string>
    <key>StartInterval</key>
    <integer>3</integer>
  </dict>
</plist>

还有错误:

Traceback (most recent call last):
  File "/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py", line 5, in <module>
    from appscript import app, its
ImportError: No module named appscript

python 脚本在命令行中运行良好。

【问题讨论】:

    标签: python launchd


    【解决方案1】:

    可能是系统 Python (/usr/bin/python) 正在启动以执行您的脚本,而不是您安装了 appscript 的 MacPorts Python (/opt/local/bin/python2.6)。什么应该起作用(未经测试!)是将MacPorts Python路径作为第一个Program Argument插入脚本路径之前。在这种情况下,您不需要指定PYTHONPATH。从理论上讲,只要 MacPorts Python 的配置与系统 Python 兼容(即类似的拱门、部署目标等),您就可以使您拥有的东西工作,但您可能不希望或不需要走这条路.

    另一种方法是将脚本的 shebang 行(第一行)更改为 MacPorts Python 的显式路径:

    #!/opt/local/bin/python2.6
    

    这在命令行 shell 中起作用的原因可能是您的一个 shell 配置文件,比如 .bash_profile,首先修改了 PATH 环境变量以包含 MacPorts Python (/opt/local/bin) 的路径,以便/usr/bin/env python 首先找到 MacPython python。通过launchd 运行时,不涉及shell,因此不会发生PATH 操作;只搜索默认路径,这意味着/usr/bin/env python 执行/usr/bin/python

    【讨论】:

    • 谢谢!我完全看错了方向。我修复了它,所以我的设置脚本用which python 的输出替换了shebang 路径。为了完整起见,我将 EnvironmentVariable 留在那里,并为 PATH 添加了一个键。
    【解决方案2】:

    您还可以在 ProgramArguments 中使用 python 的完整路径。 (更多详情:Running Python Script with Launchd: imports not found

       <key>ProgramArguments</key>
        <string>/path/to/your/python</string>
        <string>/path/to/your/script</string>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-12-30
      • 1970-01-01
      • 2013-03-10
      • 2021-08-17
      • 2018-06-07
      • 1970-01-01
      • 2011-06-28
      • 2021-05-18
      相关资源
      最近更新 更多