我有一段代码旨在每8周向Google工作表中的地址列表发送一次重复发送的电子邮件。 它似乎没有发送邮件。
我尝试了各种在网上找到的示例,但没有成功
ScriptApp.newTrigger("sendEmails")
.timeBased()
.onWeekDay(ScriptApp.WeekDay.THURSDAY)
.atHour(11)
.nearMinute(00)
.everyWeeks(8)
.create();
function sendEmails() {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("EMAILS")
var startRow = 2;
var numRows = sheet.getRange(1,4).getValue();
var dataRange = sheet.getRange(startRow, 1, numRows, 2)
var data = dataRange.getValues();
for (i in data) {
var row = data[i];
var emailAddress = row[0];
var message = row[1];
var subject = "mail subject here";
MailApp.sendEmail(emailAddress, subject, message);
}
}
当我手动运行脚本时,它似乎运行良好,所以我猜问题出在新的触发器部分?
答案 0 :(得分:1)
当前,您已经有了代码,但是由于它不是函数的一部分,因此根本不会使用它。
每8周触发一次运行代码。
将触发器生成器分离为单独的函数。
运行以下脚本,它将删除您可能不小心设置的所有触发器,并创建一个可以按预期运行的新触发器。
function newTrigger() {
//clear all triggers
var tg = ScriptApp.getProjectTriggers();
if(tg.length>0){
for(i=0;i<tg.length;i++){
ScriptApp.deleteTrigger(tg[i]);
}
}
//build new trigger
ScriptApp.newTrigger("sendEmails")
.timeBased()
.onWeekDay(ScriptApp.WeekDay.THURSDAY)
.atHour(11)
.nearMinute(00)
.everyWeeks(8)
.create();
}
.everyWeeks(8)
在代码中指定的那样,每8周运行一次。