我有一个脚本,该脚本为从母版纸上绘制的一组数据运行一个函数。每次运行该函数时,它都会基于工作表中的单元格(单元格A3)中指定的日期绘制和处理数据集。此单元格中的日期通过“ for”循环针对我指定的日期范围进行了更新。该脚本可以在第6次运行中的某些时间段内执行“超过最大执行时间”之前,可以执行这些循环的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个周期后是否有暂停脚本和恢复运行的途径。非常感谢您的帮助。
感谢这些想法使我成功了。我已经找到了以下代码的答案,该代码从gitHub的benlcollins略微改编而来。正如@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();
}
}