在OSX启动时运行Python脚本

时间:2015-05-09 20:17:32

标签: python macos plist launchctl

我有一个Python脚本,我想在登录Mac时立即执行。我在互联网上尝试了各种方法。但它们似乎都不起作用。

我尝试将com.username.scriptname.plist文件放在Library / LaunchAgents中。

<?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.username.scriptname</string>

  <key>Program</key>
  <string>/Users/username/scriptlocation/scriptname.py</string>

  <key>RunAtLoad</key>
  <true/>

  <key>StandardErrorPath</key>
  <string>/tmp/com.username.scriptname.err</string>

  <key>StandardOutPath</key>
  <string>/tmp/com.username.scriptname.out</string>
</dict>
</plist>

我将脚本放在.plist文件中提到的位置,然后执行以下操作 launchctl load /Library/LaunchAgents/com.username.scriptname.plist。 但似乎没有任何事情发生。我错过了任何步骤或做错了吗?我需要更改任何设置吗?

错误:

->grep com.username.scriptname /var/log/syslog
grep: /var/log/syslog: No such file or directory

->launchctl list com.username.scriptname
{
    "StandardOutPath" = "/tmp/com.username.scriptname.out";
    "LimitLoadToSessionType" = "Aqua";
    "StandardErrorPath" = "/tmp/com.username.scriptname.err";
    "Label" = "com.username.scriptname";
    "TimeOut" = 30;
    "OnDemand" = true;
    "LastExitStatus" = 19968;
    "Program" = "/Users/username/scriptname.sh";
};

当我有一个Python文件时,它显示了scriptname.sh的奇怪之处!

1 个答案:

答案 0 :(得分:2)

这个.plist看起来是正确的,所以一定有问题(我的猜测:不是可执行文件或错误的脚本路径)。

您可以做些什么来调试:

  • 检查系统日志中有关您工作的内容:grep com.username.scriptname /var/log/syslog。可能有com.apple.xpc.launchd[1] (com.username.scriptname[PID]): Could not find and/or execute program specified by service: 13: Permission denied: /Users/username/scriptlocation/scriptname.py
  • 之类的内容
  • 检查发布者对您的工作的评价:launchctl list com.username.scriptname
  • 另外:launchctl list | grep com.username.scriptname说什么?

还要注意man launchd.plist要说的内容:

  

<强> RunAtLoad <boolean>        此可选键用于控制作业加载时是否启动作业。默认值为false。 这个键应该是        避免,因为推测性的工作启动会对系统启动和用户登录方案产生负面影响。

相关问题