使用Google Spreadsheet和Google Script发送多个附件

时间:2018-12-04 17:20:04

标签: email google-apps-script google-sheets google-drive-api gmail

我正在尝试使用Google Spreadsheet发送多个附件,但出现以下错误“无法检索下一个对象:迭代器已到达末尾。”

它确实可以工作,因为它将电子邮件发送到列表中的第一个电子邮件地址,但对于第二个电子邮件地址却失败。

我在这里看到过类似的问题,但是没有解决方案可以解决我的问题。

以下是脚本:

function sendEmails() {
var sheet = SpreadsheetApp.getActiveSheet();
var startRow = 1;
var numRows = 2; 
var dataRange = sheet.getRange(startRow, 1, numRows, 2);
var file1 = DriveApp.getFilesByName('Maandbrief December.pdf');
var file2 = DriveApp.getFilesByName('Weekendbrief 7-9 december.pdf');
var data = dataRange.getValues();
for (i in data) {
    var row = data[i];
    var emailAddress = row[0];
    var message = row[1];
    var subject = "Maandbrief December en weekendbrief 7-9 december"; 
    MailApp.sendEmail({to:emailAddress, subject:subject, body:message, attachments: [file1.next(), file2.next()]})
}}

感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

尝试一下:

function sendEmails() {
  var sheet = SpreadsheetApp.getActiveSheet();
  var startRow = 1;
  var numRows = 2; 
  var dataRange = sheet.getRange(startRow, 1, numRows, 2);
  var files1 = DriveApp.getFilesByName('Maandbrief December.pdf');
  while(files1.hasNext()){var file1=files1.next();}
  var files2 = DriveApp.getFilesByName('Weekendbrief 7-9 december.pdf');
  while(files2.hasNext()){var file2=files2.next();}
  var data = dataRange.getValues();
  for (var i=0;i<data.length;i++) {
    var row = data[i];
    var emailAddress = row[0];
    var message = row[1];
    var subject = "Maandbrief December en weekendbrief 7-9 december"; 
    MailApp.sendEmail({to:emailAddress, subject:subject, body:message, attachments: [file1, file2]})
  }
}

或者这个:

function sendEmails() {
  var sheet = SpreadsheetApp.getActiveSheet();
  var startRow = 1;
  var numRows = 2; 
  var dataRange = sheet.getRange(startRow, 1, numRows, 2);
  var n1=0;
  var n2=0;
  var files1 = DriveApp.getFilesByName('Maandbrief December.pdf');
  while(files1.hasNext()){var file1=files1.next();n1++;}
  var files2 = DriveApp.getFilesByName('Weekendbrief 7-9 december.pdf');
  while(files2.hasNext()){var file2=files2.next();n2++}
  var data = dataRange.getValues();
  if(n1==1 && n2==1){
    for (var i=0;i<data.length;i++) {
      var row = data[i];
      var emailAddress = row[0];
      var message = row[1];
      var subject = "Maandbrief December en weekendbrief 7-9 december"; 
      MailApp.sendEmail({to:emailAddress, subject:subject, body:message, attachments: [file1, file2]});
    }
  }else{
    throw('More than one file with given name.');
  }
}