javascript - 超过最大执行时间谷歌表格脚本解决方法

标签 javascript google-apps-script google-sheets execution-time

我有一个脚本,它为从主表中提取的一组数据运行一个函数。每次运行该函数时,它都会根据工作表单元格(单元格 A3)中指定的日期绘制并处理数据集。此单元格中的日期通过“for”循环针对我指定的日期范围进行更新。在我在第六次运行期间遇到“超出最大执行时间”之前,脚本可以执行这些循环的 5 次完整运行(即每次运行执行相当于一天数据的函数)。每次运行后,我的所有数据都已以持续更新的方式保存到电子表格中,因此在五个周期后我必须做的是通过修改脚本从第 6 天开始手动重新启动运行 5 天。我正在阅读 time driven trigger有人每 5 分钟暂停一次脚本以绕过 6 分钟的执行时间限制,但这不符合我的需求,因为我想在每 5 个周期后休息一次(不是基于时间)。我需要的是编写一个脚本,在运行 5 个周期后,该脚本可以中断,然后再次恢复运行另外 5 个周期。我的代码如下所示:

function runMultipleDates() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();

  var start = new Date("2018-11-05");
  var end = new Date("2018-11-09"); 
  var step = 1;

  for (var date1 = start; date1 <= end; date1.setDate(date1.getDate() + step)) {
    var date2 = new Date(date1.getTime());
    date2.setDate(date2.getDate() + 1);
    ss.getSheetByName('Time Range').getRange("A3").setValue(date2);
    runEverything();

  };
}

如您所见,现在我正在手动调整开始和结束日期 5 天,让它运行,然后通过将脚本开始日期调整为 2018-11-09 并将结束日期调整为2018年11月13日进行下一次运行。该函数本身能够运行远超过 5 天的周期,而没有执行时间限制。所以问题是是否有办法暂停脚本并在上述脚本的 5 个周期后恢复运行。非常感谢任何帮助。

最佳答案

感谢您向我发送的想法。我已经找到了这个问题的答案,以下代码稍微改编自 benlcollins在 GitHub 上。正如 @Cooper 所建议的,我每 5.5 分钟运行一次函数,这比我完成主函数 runMultipleDates() 所花费的时间要多一点(该函数一次自行处理 5 天);我重复了 20 次,这意味着它将覆盖 20x5=100 天,这对我来说已经足够了。我发布此内容是为了对某人有所帮助。

// -----------------------------------------------------------------------------
// add menu
// -----------------------------------------------------------------------------
function onOpen() { 
  var ui = SpreadsheetApp.getUi();
  ui.createMenu("Auto Trigger")
    .addItem("Run","runAuto")
    .addToUi();
}
function runAuto() {  
  // resets the loop counter if it's not 0
  refreshUserProps(); 
  // create trigger to run program automatically
  createTrigger();
}

function refreshUserProps() {
  var userProperties = PropertiesService.getUserProperties();
  userProperties.setProperty('loopCounter', 0);
}

function createTrigger() {
    ScriptApp.newTrigger('runGlobal')
      .timeBased()
      .everyMinutes(5.5)
      .create();
}

// -----------------------------------------------------------------------------
// function to delete triggers
// -----------------------------------------------------------------------------
function deleteTrigger() {
  
  // Loop over all triggers and delete them
  var allTriggers = ScriptApp.getProjectTriggers();
  
  for (var i = 0; i < allTriggers.length; i++) {
    ScriptApp.deleteTrigger(allTriggers[i]);
  }
}

// -----------------------------------------------------------------------------
// function to run called by trigger once per each iteration of loop
// -----------------------------------------------------------------------------
function runGlobal() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getSheetByName('Data');  
  // get the current loop counter
  var userProperties = PropertiesService.getUserProperties();
  var loopCounter = Number(userProperties.getProperty('loopCounter'));  
  var limit = 20; // create trigger to run program automatically  
  // if loop counter < limit number, run the repeatable action
  if (loopCounter < limit) {       
    // do stuff
    runMultipleDates();   
    // increment the properties service counter for the loop
    loopCounter +=1;
    userProperties.setProperty('loopCounter', loopCounter);    
    // see what the counter value is at the end of the loop
    Logger.log(loopCounter);
  }
  // if the loop counter is no longer smaller than the limit number
  else {
    Browser.msgBox("Run Completed");    // Log message to confirm loop is finished
    deleteTrigger(); 
  }  
}

关于javascript - 超过最大执行时间谷歌表格脚本解决方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58983029/

相关文章:

javascript - IE 数组中的appendChild 不起作用

javascript - 使用 javascript 上传 YouTube 视频

google-apps-script - 使用 google apps 脚本保护范围

javascript - Google Apps 脚本连接数字而不是相加

javascript - jQuery.csv() 插件未知错误

Javascript OOP 和类

google-apps-script - 需要帮助使用 Google Apps 脚本在 Google 表格中的列中查找最大值

google-apps-script - 找不到具有给定 ID 的项目,或者您无权访问它

google-sheets - 使用 ArrayFormula 唯一过滤多个工作表

google-apps-script - onOpen() 函数在桌面上触发,但在 Android 上不触发