谷歌脚本 - 将 Gmail 附件添加到文档和云端硬盘中的处理



所以基本上,我父亲让我创建一个脚本来查找带有"驱动器"标签的电子邮件,并将其内容保存到他的驱动器中。(如果你问为什么,这样他就可以通过电子邮件给自己发几个PDF,并让脚本自动将它们放在他的驱动器中)

我已经完成了整件事,除了一件事:无法弄清楚如何保存附件。在processDocument方法中,我遍历附件并尝试执行以下操作:

doc.appendParagraph(the attachment)

是否有使用processDocument()方法添加附件的正确方法?

代码链接:http://pastebin.com/RwFNs232

谢谢。

可以使用 DriveApp 将附件 blob 保存在单独的文件中:

var fileBlob = "your blob" // GmailAttachment.copyBlob() method;
var file = DriveApp.createFile(blob);

然后在您的文档中写下附件的链接

doc.appendParagraph(file.getUrl());

注意:

您可能希望在文档中编写附件内容。在这种情况下,您可以直接写入文档,而无需在云端硬盘中创建文件。但这很危险,因为无法将某些 blob 的内容作为格式良好的字符串获取。

doc.appendParagraph("attachment content"); //GmailAttachment.getDataAsString() 

我认为它会解决你的问题。

正如@nanndoj所说,您应该使用 blob 文件结构来输入文件。有关 Blob 的其他信息应作为单独的问题提出。

但是,附件不应仅附加到电子邮件的doc。相反,您应该在 sendEmail 函数的调用中包含 blob 引用,如此处的 Google 文档所示。

例:

sendEmail(recipient, subject, body, options)
MailApp.sendEmail('mike@example.com', 'Attachment example', 'Two files are attached.', {
     name: 'Automatic Emailer Script',
     attachments: [file.getAs(MimeType.PDF), blob]
 });

相关内容

  • 没有找到相关文章

最新更新