使用Launchd运行Python脚本:未找到导入

时间:2013-03-20 23:25:03

标签: python osx-mountain-lion launchd

我一直在尝试设置一个脚本,使用launchd定期运行python程序。 python程序失败,因为它无法找到我的导入---我知道这是因为我在日志文件中捕获了错误。要解决此问题,我创建了~\.MacOSX\environment.plist,并在那里复制了我的PYTHONPATH,注销并再次登录。这似乎不足以解决问题,我不知道还有什么可以尝试。

我正在运行OSX,10.8.3。

相关主题:

更新:

似乎我可以运行以下命令:

launchctl setenv PYTHONPATH $PYTHONPATH

并且脚本将成功执行。所以,修改我的问题:

  1. 这个存储在哪里?我检查了~\.launchd.conf\etc\.launchd.conf,两者都不存在。
  2. 当我重新启动时,可能会转储此设置。我在哪里可以更改此信息,以便launchd能够找到它?

2 个答案:

答案 0 :(得分:6)

要设置特定作业的环境,您应该在作业定义中使用EnvironmentVariables键:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.example.app</string>
    <key>Program</key>
    <string>/path/to/your/script</string>
    <key>EnvironmentVariables</key>
    <dict>
        <key>PYTHONPATH</key>
        <string>/your/python/path</string>
    </dict>
</dict>
</plist>

您可以通过编辑守护程序的launchd(8)或代理程序的/etc/launchd.conf来为/etc/launchd-user.conf服务定义默认环境变量。后者可以工作,但没有记录。当前记录的(但不受支持的)每用户配置文件为$HOME/.launchd.conf

这些配置文件包含launchctl(1)子命令列表。你想要的是:

setenv PYTHONPATH /your/python/path
Mac OS X 10.10及更高版本不支持

更新: /etc/launchd.conf。在这些系统上,您必须基于每个作业定义环境变量。

答案 1 :(得分:2)

以上都不适用于我(OS X 10.11.3)。突破是阅读这个script runs fine in terminal but not from launchd并意识到人们可以用正确的模块编写python版本的绝对完整路径。 D'哦。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.example.app</string>
    <key>ProgramArguments</key>
    <string>/path/to/your/python</string>
    <string>/path/to/your/script</string>
</dict>
</plist>