javascript - 我无法通过谷歌脚本发送带有 pdf 作为附件的电子邮件

标签 javascript google-apps-script google-sheets google-drive-api

我正在制作一个脚本,该脚本获取电子表格,将其转换为 pdf 文件,并将该 pdf 保存在文件夹中,然后通过电子邮件将其作为附件发送。但是,我使用的是我发现的唯一通过电子邮件发送附件的功能,但是当我打开电子邮件时,它会在电子邮件上显示消息“[object Object]”。有人能帮我吗?

function SendEmail(){



  var sheetMail = SpreadsheetApp.getActiveSpreadsheet();
  var ecrvc = sheetMail.getSheetByName('List');
  var planilha = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('List')
  var 
  var subject = "Subject"
  var message = "message"


  var email = "person1@gmail.com"


//var ecrvc = "Sheet1";
var folderID = "folderId"; // Folder id to save in a folder.
var pdfName = "YourSpreadsheet of "+week+"-20";

var sourceSpreadsheet = SpreadsheetApp.getActive();
var sourceSheet = sourceSpreadsheet.getSheetByName(ecrvc);
var folder = DriveApp.getFolderById(folderID);

//Copy whole spreadsheet
var destSpreadsheet = SpreadsheetApp.open(DriveApp.getFileById(sourceSpreadsheet.getId()).makeCopy("tmp_convert_to_pdf", folder))


var destSheet = destSpreadsheet.getSheets()[0];

//save to pdf
var theBlob = destSpreadsheet.getBlob().getAs('application/pdf').setName(pdfName);
var newFile = folder.createFile(theBlob);

//Delete the temporary sheet
DriveApp.getFileById(destSpreadsheet.getId()).setTrashed(true);




//Send the email with attachments  
var arquivo = theBlob;
 DriveApp.getFileById(theBlob); 

  MailApp.sendEmail(email, subject,{
     // htmlBody: message + "", noReply:true,{
    attachments: [file.getAs.file(arquivo.PDF)],
    name: pdfName
  });   

}

最佳答案

有几个问题

file 未声明,getAs 语法错误。

示例取自https://developers.google.com/apps-script/reference/mail/mail-app#sendemailrecipient,-subject,-body,-options

// Send an email with two attachments: a file from Google Drive (as a PDF) and an HTML file.
var file = DriveApp.getFileById('1234567890abcdefghijklmnopqrstuvwxyz');
var blob = Utilities.newBlob('Insert any HTML content here', 'text/html', 'my_document.html');
MailApp.sendEmail('mike@example.com', 'Attachment example', 'Two files are attached.', {
    name: 'Automatic Emailer Script',
    attachments: [file.getAs(MimeType.PDF), blob]
});

关于javascript - 我无法通过谷歌脚本发送带有 pdf 作为附件的电子邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60469439/

相关文章:

google-apps-script - 查找一列中的值,如果匹配则添加来自不同列的值 Google Script Google Sheets

performance - 谷歌应用程序脚本 : copying spreadsheet is very slow

google-apps-script - 错误的日期谷歌电子表格

javascript - 在 Outlook Web Access (OWA) 中阅读电子邮件 header

java - 将变量存储到我的服务器

javascript - Angular2 中的深层链接

api - 使用 google 应用脚本进行 Shopify 身份验证 OAuthConfig 类

google-apps-script - 谷歌脚本超时

javascript - 简单 "Delete Sheet/Insert Sheet"脚本的服务器错误

javascript - 谷歌应用程序脚本 : How to horizontally align an inlineImage