使用 appscript 在 Gmail 中批量发送带有相应附件的电子邮件 修改点:修改后的脚本:注意:参考:

如何解决使用 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。从这种情况来看,我认为这些文件可能是公开共享的,也可能是您的文件。如果我的理解是正确的,我认为您可以使用 DriveAppDrive 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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?