使用Apps脚本将Gmail附件复制到Google云端硬盘

时间:2020-03-05 18:35:16

标签: google-apps-script gmail gmail-api

我正在使用Google Apps脚本自动将电子邮件中的附件保存到唯一的Google云端硬盘文件夹中,具体取决于邮件被过滤到的标签。

到目前为止,我已经使用网上找到的一些代码片段设法获得了消息ID。但是,我一直试图访问邮件正文并将附件保存到驱动器文件夹中。

function getMessage(){
     var folder = DriveApp.getFolderById('xxxxxxxxxxxxx');
     var userId = "myemail@gmail.com";
     var query = "label:Global Alcohol";
     var res = Gmail.Users.Messages.list(userId, {q: query});
     var attachment = msgs.Attachments.get(userId, messageId, id);
     var ids = res.messages.map(function(e){return e.id});
     Logger.log(ids);// Message IDs with the specific labels.
     }

预先感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

尝试一下:

function saveAttachmentInFolder(){
  var folder = DriveApp.getFolderById('xxxxxxxxxxxxx');
  var userId = "myemail@gmail.com";
  var query = "label:Global Alcohol";
  var res = Gmail.Users.Messages.list(userId, {q: query});//I assumed that this works
  res.messages.forEach(function(m){
    var attA=GmailApp.getMessageById(m.id).getAttachments();
    attA.forEach(function(a){
      var ts=Utilities.formatDate(new Date(),Session.getScriptTimeZone(), "yyMMddHHmmss");
      folder.createFile(a.copyBlob()).setName(a.getName()+ts);
    });
  });
}
相关问题