“需要一个正面的复发频率”谷歌应用程序时钟触发器

时间:2012-11-01 10:51:48

标签: triggers google-apps-script builder clock

我正在尝试创建基于时钟的触发器。这是谷歌应用程序脚本。该脚本应该调用一个函数,该函数将在早上5点从电子表格发送电子邮件信息。我知道这个功能是有效的,因为我已经在早上5点到早上6点使用了触发器,但他们想要它在凌晨5点,而不是在那个小时范围内的任何时间。这是我的代码:

var SOD_Briefing_Trigger = ScriptApp.newTrigger("sendBriefingByEmail")
.timeBased().
atHour(5)
.create();

每当我尝试运行或调试它时,都会收到以下错误消息:

Needs a positive frequency of recurrence

很抱歉,这似乎是一个新问题。我花了几天时间在这里搜索,谷歌一般都在寻找类似的问题。我找不到任何东西。

2 个答案:

答案 0 :(得分:1)

该错误消息 有点神秘。如果您只是说“atHour”,系统会知道“时间”而不是“频率”。

以下内容应该有效。

var SOD_Briefing_Trigger = ScriptApp.newTrigger("sendBriefingByEmail")
.timeBased()
.atHour(5)
.everyDays(1)
.create();

请注意“everyDays”电话。这意味着每隔X天运行一次 - 在此次通话中每天运行一次。您可以根据记录的here调用将其更改为其他频率。其他一些例子 - “atDate”(如果你只想让它今天运行或tomrorow)和“onWeekDay”(如果你想让它每周一运行,例如。)。

答案 1 :(得分:0)

我能够通过一个简单的函数让它工作一次,该函数只是给我发了一封短信的电子邮件。从那时起,我就无法让它根据电子表格向我发送更长的电子邮件。

这是我试图运行的整个代码,今天0500没有发送任何内容。

function createTimeTrigger3() {

  try{



  var SOD_Briefing_TriggerMonday = ScriptApp.newTrigger("sendBriefingByEmail2")
      .timeBased()
      .atHour(5)
      .nearMinute(15)
      .onWeekDay(ScriptApp.WeekDay.MONDAY)
      .create();

    var SOD_Briefing_TriggerTuesday = ScriptApp.newTrigger("sendBriefingByEmail2")
      .timeBased()
      .atHour(5)
        .nearMinute(15)
      .onWeekDay(ScriptApp.WeekDay.TUESDAY)
        .create();

    var SOD_Briefing_TriggerWednesday = ScriptApp.newTrigger("sendBriefingByEmail2")
      .timeBased()
      .atHour(5)
        .nearMinute(15)
      .onWeekDay(ScriptApp.WeekDay.WEDNESDAY)
        .create();

    var SOD_Briefing_TriggerThursday = ScriptApp.newTrigger("sendBriefingByEmail2")
      .timeBased()
      .atHour(5)
        .nearMinute(15)
      .onWeekDay(ScriptApp.WeekDay.THURSDAY)
        .create();

    var SOD_Briefing_TriggerFriday = ScriptApp.newTrigger("sendBriefingByEmail2")
      .timeBased()
      .atHour(5)
        .nearMinute(15)
      .onWeekDay(ScriptApp.WeekDay.FRIDAY)
        .create();


  }
  catch(err)
  {
     MailApp.sendEmail("************.gov", "there was a problem with the SOD trigger", err.message);

}

   Logger.log("Unique ID of SOD_Briefing_TriggerMonday: " + SOD_Briefing_TriggerMonday.getUniqueId());
    Logger.log("Unique ID of SOD_Briefing_TriggerTuesday: " + SOD_Briefing_TriggerTuesday.getUniqueId());
    Logger.log("Unique ID of SOD_Briefing_TriggerWednesday: " + SOD_Briefing_TriggerWednesday.getUniqueId());
    Logger.log("Unique ID of SOD_Briefing_TriggerThursday: " + SOD_Briefing_TriggerThursday.getUniqueId());
    Logger.log("Unique ID of SOD_Briefing_TriggerFriday: " + SOD_Briefing_TriggerFriday.getUniqueId());
      Logger.log("Unique ID of SOD_Briefing_TriggerToday: " + SOD_Briefing_TriggerToday.getUniqueId());


}

function sendBriefingByEmail2() {


  var email = SpreadsheetApp.openById("***********").getSheetByName("Email Roster").getRange(4, 3).getValue()
      +SpreadsheetApp.openById("***************").getSheetByName("Email Roster").getRange(5, 3).getValue()
      +SpreadsheetApp.openById("***************").getSheetByName("Email Roster").getRange(6, 3).getValue()
      +SpreadsheetApp.openById("***************").getSheetByName("Email Roster").getRange(7, 3).getValue()
      +SpreadsheetApp.openById("*************").getSheetByName("Email Roster").getRange(8, 3).getValue()
      +SpreadsheetApp.openById("*********************").getSheetByName("Email Roster").getRange(9, 3).getValue()
      +SpreadsheetApp.openById("**********************").getSheetByName("Email Roster").getRange(10, 3).getValue()
      +SpreadsheetApp.openById("**************").getSheetByName("Email Roster").getRange(11, 3).getValue()
      +SpreadsheetApp.openById("**********************").getSheetByName("Email Roster").getRange(12, 3).getValue();

      if (SpreadsheetApp.openById("**********************").getSheetByName("Previous_24_Hours").getRange(2, 1).isBlank()){

        try {

      MailApp.sendEmail(email, "No SOD Daily Briefing to Report Today", "There were no daily briefing entries submitted for SOD in the previous 24 hours.");

        }

        catch(err){ 
  MailApp.sendEmail("*************.gov", "there was a problem sending the SOD BLANK briefing in the AM", err.message);
}


        }




    else {

      try {

  var subject = "Special Operations Bureau Daily Briefing";

  var row = 2;

      var email24sheet = SpreadsheetApp.openById("*********************").getSheetByName("Previous_24_Hours");


  var LastRow = SpreadsheetApp.openById("******************").getSheetByName("Previous_24_Hours").getLastRow();




  var msgHtml = ""

      do {
      msgHtml = msgHtml + "<br><hr><br>"

      +"<p>"+"<b>"+"Unit: "+"</b>"+email24sheet.getRange(row, 11).getValue()+"</p>"
      +"<p>"+"<b>"+"Incident: "+"</b>"+email24sheet.getRange(row, 1).getValue()+"</p>"
      +"<p>"+"<b>"+"Date / Time: "+"</b>"+email24sheet.getRange(row, 2).getValue()+ " @ " + email24sheet.getRange(row, 3).getValue()+ " hours"+"</p>"
      +"<p>"+"<b>"+"Location: " + "</b>" +email24sheet.getRange(row, 4).getValue()+"</p>"      
        +"<p>"+"<b>"+"Trooper: "+"</b>"+email24sheet.getRange(row, 5).getValue()+"</p>"
        +"<p>"+"<b>"+"Assisting Trooper(s): "+"</b>"+email24sheet.getRange(row, 6).getValue()+"</p>"
     +"<p>"+"<b>"+"Suspect: "+"</b>"+email24sheet.getRange(row, 7).getValue()+"</p>"
       +"<p>"+"<b>"+"Charges: "+"</b>"+email24sheet.getRange(row, 8).getValue()+"</p>"
      +"<p>"+"<b>"+"Yield: "+"</b>"+email24sheet.getRange(row, 9).getValue()+"</p>"
          +"<p>"+"<b>"+"Synopsis: "+"</b>"+email24sheet.getRange(row, 10).getValue()+"</p>";
row = row + 1;

} while(row < LastRow+1);


  var msgHeader = "<p>"+"<H1>"+"<P ALIGN=Center>"+"Special Operations Bureau Daily Briefing"+"</H1>"+"</p>"
        +"<p>"+"<H2>"+"<P ALIGN=Center>"+"Created: " + new Date().toLocaleDateString()+"</H2>"+"</p>";

  var msgFooter = "<p>"+"<i>"+"<P ALIGN=Center>"+"This message was automatically generated using data submitted electronically from the Spec Ops Bureau website and / or form.  For errors or suggestions for improvements, email **************.gov "+"</i>"+"</p>";

    var msgPlain = msgHtml.replace(/(<([^>]+)>)/ig, ""); // clear html tags for plain mail


  MailApp.sendEmail(email, subject, msgPlain, { htmlBody: msgHeader + msgHtml + msgFooter });

    SpreadsheetApp.openById("*************").getSheetByName("Previous_24_Hours").getRange("Previous_24_Data").clearContent(); //clears the incidents that were just sent

  }

catch(err){ 
  MailApp.sendEmail("**************.gov", "there was a problem sending the SOD briefing in the AM", err.message);
}

}

  }

我在0500没有得到任何东西。然后我尝试制作更多的触发器来测试触发器构建器并尝试不同的东西来看看我能做些什么。

我使用了从google脚本网站(https://developers.google.com/apps-script/managing_triggers_programmatically)找到的命令来删除触发器:

// Delete a trigger with the given unique ID
function deleteTrigger(triggerId) {
  // Locate a trigger by unique ID
  var allTriggers = ScriptApp.getScriptTriggers();
  // Loop over all triggers
  for(var i=0; i < allTriggers.length; i++) {
    if (allTriggers[i].getUniqueId() == triggerId) {
      // Found the trigger and now delete it
      ScriptApp.deleteTrigger(allTriggers[i]);
      break;
    }
  }
}

但现在我得到了:

  

此脚本有太多触发器。必须从中删除触发器   可以添加更多脚本。

  

已经设置了定期时钟触发器。

当我尝试运行任何内容时,错误消息通过电子邮件发送给我。

我是否应该为本周的每一天触发器执行不同的功能?