我试图测试我正在处理的脚本。脚本很好,当我手动触发它时它会成功执行。当我添加每分钟间隔的时间驱动脚本时,抄写员会在几小时后开始抛出异常。
异常:服务在一天内被调用了太多次:gmail
我检查了每日电子邮件配额,发现我还有邮件配额
var quota = MailApp.getRemainingDailyQuota();
Logger.log(quota);
此外,我可以收到try catch电子邮件,但邮件不会被转发。
这是因为与触发器相关的执行时间配额吗?以下是代码
function MailForward() {
try{
var glabel = createLabel_("Mail-Forwarded");
var rtm_email = 'abc@abc.com';
var from_email = Session.getActiveUser().getEmail();
var threads = GmailApp.search('in:inbox is:unread newer_than:1d');
var mForward = 0;
for (var i=0;i<threads.length;i++) {
var messages=threads[i].getMessages();
for (var m = 0; m < messages.length; m++){
if (messages[m].isUnread()){
mForward = 0;
var mlabels = threads[i].getLabels();
for (var j = 0; j < mlabels.length; j++) {
Logger.log(mlabels[j].getName());
if (mlabels[j].getName() === "Mail-Forwarded") {
mForward = 1;
}
}
if (mForward===0) {
// Logger.log(messages.length)
// Logger.log(messages[m].getFrom());
var from = messages[m].getFrom();
//Logger.log(messages[m].getDate());
var date = messages[m].getDate();
// Logger.log(messages[m].getSubject());
var subject = messages[m].getSubject();
// Logger.log(messages[m].getTo());
var to = messages[m].getTo();
var body = messages[m].getBody();
var attachment = messages[m].getAttachments();
var emailoptions = ("---------- Forwarded message ----------" +'<br>'+'From: '+from+ "<'" + from.replace(/^.+<([^>]+)>$/, "$1") +"'>"+'<br>'+ 'Date: '+date+'<br>'+ 'Subject: ' +subject+'<br>'+
'To: ' +to+ "<'" + to.replace(/^.+<([^>]+)>$/, "$1") +"'>"+'<br>'+'<br>'+'<br>');
messages[m].forward(rtm_email,{htmlBody: emailoptions + body , Attachment: attachment});
glabel.addToThread(threads[i]);
Logger.log(glabel.getName());
messages[m].markRead();
mForward = 1;
}
}
}
}
} catch(e) {
MailApp.sendEmail("abc@abc.com", "Exception found in Sript", e );
Logger.log(e);
}
}
答案 0 :(得分:1)
您使用MailApp.getRemainingDailyQuota();
而不是GmailApp
检查了配额。这是两种不同的服务。
quota method仅返回“用户当天剩余时间可以发送的剩余电子邮件数量。”但是你要达到的限制是你为什么目的调用服务的次数。
您正在使用GmailApp
来访问现有消息,而不是发送新消息。特别是,您正在检查今天每个线程中的每条消息,并且每分钟。这是很多API调用:getMessages
,isUnread
等等。
减少API调用次数的一种方法是进行更有针对性的搜索。 after:
搜索参数接受Unix时间戳,这使得可以执行以下操作:
function doSomethingWithNewEmail() {
var interval = 5; // if the script runs every 5 minutes; change to 1 if it runs every minute
var date = new Date();
var timeFrom = Math.floor(date.valueOf()/1000) - 60 * interval;
var threads = GmailApp.search('is:inbox after:' + timeFrom);
for (var i = 0; i < threads.length; i++) {
// do something
}
}
我成功地使用了上述方法,间隔为5分钟。它也可以使用1分钟,因为大多数时间search
将是脚本发出的唯一API调用。