launchd执行python脚本,但导入失败

时间:2011-04-06 22:04:39

标签: python launchd

我使用appscript编写了一个python脚本来跟踪我当前活动的窗口。我通过launchd运行它,但是当我这样做时它无法导入appscript。我已将plY中的PYTHONPATH设置为launchd,但我认为launchd不是在site-packages中读取.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脚本在命令行中运行良好。

2 个答案:

答案 0 :(得分:6)

可能是系统Python(/usr/bin/python)正在启动以执行您的脚本,而不是安装了/opt/local/bin/python2.6的MacPorts Python(appscript)。应该做什么(未经测试!)是在脚本路径之前插入MacPorts Python路径作为第一个Program Argument。在这种情况下,您不需要指定PYTHONPATH。理论上,只要MacPorts Python与系统Python兼容地配置(即类似的arch,部署目标等),你就可以完成你的工作,但你可能不应该或者需要沿着这条路走下去

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

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

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

答案 1 :(得分:0)

您还可以在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>