如何解决使用 appscript 在 Gmail 中批量发送带有相应附件的电子邮件 修改点:修改后的脚本:注意:参考:
我想使用电子表格批量发送带有附件的 Google 邮件。在此 spreadsheet 中,我已经输入了电子邮件地址、内容模板和相应的附件网址。
当我尝试执行以下代码时,除了 行项目 #21“attachments.push(file.getAs(MimeType.PDF));” 之外,一切都进行得很顺利,它显示了一个错误。当我删除第 21 行并执行时,我可以发送带有 HTML 附件的批量电子邮件,而不是包含病毒且被标记为垃圾邮件的 PDF。
有人可以用正确的代码帮助我执行相同的代码并直接发送 pdf 而不是 HTML
var EMAIL_SENT = "EMAIL_SENT";
function sendEmails() {
var sheet = SpreadsheetApp.getActiveSheet();
var startRow = 2;
var numRows = 3;
var blobs = [];
var datarange = sheet.getRange(startRow,1,numRows,5)
var data = datarange.getValues();
for (var i = 0; i < data.length; ++i) {
var row = data[i];
var emailAddress = row[2];
var subject = "Attachments";
var message = row[4];
var options = {muteHttpExceptions:true};
var attachments = UrlFetchApp.fetch(row[3],options).getBlob();
attachments.push(file.getAs(MimeType.PDF));
var emailSent = row[0];
if (emailSent != EMAIL_SENT) {
GmailApp.sendEmail(emailAddress,subject,message,{attachments: attachments,});
sheet.getRange(startRow + i,1).setValue(EMAIL_SENT);
SpreadsheetApp.flush();
}
}
}
解决方法
修改点:
- 当我看到您的脚本时,我认为您在
attachments.push(file.getAs(MimeType.PDF))
出现问题的原因是var attachments = UrlFetchApp.fetch(row[3],options).getBlob();
。在这一行,attachments
是 HTTPResponse 对象。为此,您的attachments.push(file.getAs(MimeType.PDF))
脚本尝试将file.getAs(MimeType.PDF)
置于attachments
。这样,就会发生错误。而且,file
未声明。 - 而且,当我看到您的电子表格时,我注意到该文件的 URL 是公开共享文件的链接,例如
https://drive.google.com/file/d/###/view?usp=sharing
。从这种情况来看,我认为这些文件可能是公开共享的,也可能是您的文件。如果我的理解是正确的,我认为您可以使用DriveApp
的 Drive Service 和方法 getBlob 直接检索文件。此外,正如您在 GmailApp: sendEmail 中看到的,attachments
参数内的option
参数与BlobSource
变量一起使用,与返回getBlob
相同。立>
当以上几点反映到你的脚本中时,它变成如下。
修改后的脚本:
var EMAIL_SENT = "EMAIL_SENT";
function sendEmails() {
var sheet = SpreadsheetApp.getActiveSheet();
var startRow = 2;
var numRows = 3;
var dataRange = sheet.getRange(startRow,1,numRows,5);
var data = dataRange.getValues();
for (var i = 0; i < data.length; ++i) {
var row = data[i];
var emailAddress = row[2];
var subject = "Attachments";
var message = row[4];
var fileId = row[3].split("/")[5];
var emailSent = row[0];
try {
var file = DriveApp.getFileById(fileId);
if (emailSent != EMAIL_SENT) {
GmailApp.sendEmail(emailAddress,subject,message,{ attachments: [file.getBlob()] });
sheet.getRange(startRow + i,1).setValue(EMAIL_SENT);
// SpreadsheetApp.flush(); // I think that this might not be required to be used.
}
} catch(e) {
console.log("File of " + row[3] + "cannot be retrieved. Error message is " + e.message);
}
}
}
注意:
- 在上面的脚本中,当无法检索到 URL (
row[3]
) 的文件时,可以在日志中看到该 URL。
参考:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。