问题描述
我想创建一个 Google App 脚本,通过从 Google 电子表格收集数据来获取带有签名的 Gmail 草稿。默认情况下,
function Loop_Email_Drafts() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getActiveSheet();
var index = 2;
var lastRow = sheet.getLastRow();
for (;index <= lastRow; index++){
var emailAddress = sheet.getRange(index,1,1).getValue();
var ccmail = sheet.getRange(index,2,1).getValue();
var subject = sheet.getRange(index,3,1).getValue();
var message = sheet.getRange(index,4,1).getValue();
GmailApp.createDraft(emailAddress,subject,message,{cc: ccmail});
}// End of For Loop
}// End of Function
google 应用脚本正在创建一个纯文本草稿,我无法从中添加我的签名(我的签名还包含一个图像)。
解决方法
使用 htmlBody:
如果你只是想在草稿中添加一个 HTML 正文,可以使用以下方法:
其中options
是指一个可以包含一系列高级参数的对象,包括:
- htmlBody:如果设置,能够呈现 HTML 的设备将使用它而不是所需的 body 参数;如果您的电子邮件有内联图像,则可以在 HTML 正文中添加可选的 inlineImages 字段
-
inlineImages:一个 JavaScript 对象,包含从图像键 (
String
) 到图像数据 (BlobSource) 的映射;这假设使用了htmlBody
参数并包含对这些图像的引用,格式为
也就是说,您可以在 inlineImages
中定义您想要的图像,并使用相应的 imageKey
将它们添加到您的 HTML 中。以下是如何做到这一点的示例:
const html = "<p>Whatever</p><img src=\"cid:yourImageKey\" />";
const options = {
htmlBody: html,inlineImages: {
yourImageKey: YOUR_IMAGE_BLOBSOURCE
}
}
GmailApp.createDraft(recipient,'',options);
更新:添加签名:
您实际上可以通过 Gmail API manage signatures,因此可以使用 Apps 脚本(使用 Advanced Gmail Service)。
为了将您的实际签名添加到草稿中,您可以执行以下操作:
- Enable the Advanced Gmail Service。
- 使用 users.settings.sendAs.get 检索您的签名。
- 将此签名添加到您的
htmlBody
。
const signature = Gmail.Users.Settings.SendAs
.get("me","email_address_or_alias")
.signature;
const html = "<div>YOUR_HTML_BODY</div><br>" + signature;
const options = {
htmlBody: html,cc: ccmail
}
GmailApp.createDraft(recipient,options);