launchd执行python脚本,但导入失败
作者:互联网
我使用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脚本从命令行运行良好.
解决方法:
有可能系统Python(/usr/bin/python)正在启动以执行您的脚本,而不是安装了appscript的MacPorts Python(/opt/local/bin/python2.6).什么应该工作(未经测试!)是在脚本路径之前插入MacPorts Python路径作为第一个程序参数.在这种情况下,您不需要指定PYTHONPATH.理论上,只要MacPorts Python与系统Python兼容地配置(即类似的arch,部署目标等),你就可以完成你的工作,但你可能不应该或者需要沿着这条路走下去.
另一种方法是将脚本的shebang行(第一行)更改为MacPorts Python的explict路径:
#!/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.
标签:python,launchd 来源: https://codeday.me/bug/20190531/1187899.html