首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不要将一个文件转换为脚本

不要将一个文件转换为脚本
EN

Stack Overflow用户
提问于 2021-05-10 13:00:32
回答 1查看 95关注 0票数 0

下面是代码的这一部分

代码语言:javascript
复制
      doc.saveAndClose();

      reportPDF = doc.getAs('application/pdf')
      reportPDF.setName('Doc1 - '+ rows[0][0] + ".pdf");
      
      var file = destinationFolder.createFile(reportPDF);  
      var folder = DriveApp.getFolderById("12bcF_SHkGtENTcAJrqbR_Vsd1oN7Qd3S");
      var file2 = folder.getFilesByName("Doc2.pdf");

      DriveApp.getFileById(doc.getId()).setTrashed(true);

      if(file2.hasNext()){
            var file2pdf = file2.next().getAs(MimeType.PDF);
            emails.forEach(function(email) {
            MailApp.sendEmail(email, "Subject - " + rows[0][0], "Hello!" + '\n' + '\n' + "Attached to this email is your Documents " +dadosMes , {
            name: 'Best Practices Report',
            attachments: 
              [
              file.getAs(MimeType.PDF),
              file2pdf                
              ]
                                       
             });
           })
        } 

}

代码向编译它的人发送一封电子邮件,其中包含两个已创建的PDF文档。

有没有一种简单的方法不把Doc1转换成pdf?我想发送的Doc1像一个文件在word和doc2将保持为一个pdf。

我在这里思考,做一些测试(比如删除或尝试修改reportPDF部分),但我不知道是否有“更容易”的方法。

编辑:

创建文档的部分是:

代码语言:javascript
复制
        const copy = googleDocTemplate.makeCopy('Metrics' , destinationFolder);
        const doc = DocumentApp.openById(copy.getId());
        const body = doc.getBody();
EN

回答 1

Stack Overflow用户

发布于 2021-05-10 14:52:43

答案:

若要将Google文件转换为Microsoft文件,必须使用导出链接。

代码:

代码语言:javascript
复制
/**
 * Converts Google Doc file to defined Mime Type Format
 * @param  {String} fileID   - Document ID for export
 * @param  {String} folderId - Folder ID of folder in which to save Sheet 
 * @return {Blob}   blob     - blob of the file
 */
function convertFile(fileId, mimeType) {
  // Define export endpoint and method.
  const url = `https://www.googleapis.com/drive/v3/files/${fileId}/export?mimeType=${mimeType}`
    
  const blob = UrlFetchApp.fetch(url, {
    method: "get",
    headers: {
      "Authorization": `Bearer ${ScriptApp.getOAuthToken()}`
    },
    muteHttpExceptions: true
  }).getBlob()
   
  const fileName = DriveApp.getFileById(fileId).getName()
  blob.setName(`${fileName}.docx`)

  return blob  
}

function main() {
  // This will be the ID of your Google Doc file, 'doc':
  const fileId = "file-ID" 

  const docx = convertFile(fileId, MimeType.MICROSOFT_WORD)
  const email = "example@domain.com"

  const file2 = folder.getFilesByName("Doc2.pdf")
  DriveApp.getFileById(doc.getId()).setTrashed(true);

  if(file2.hasNext()) {
    const file2pdf = file2.next().getAs(MimeType.PDF)
    MailApp.sendEmail(email, "Subject" , "Message Body", {
      "name": "Best Practices Report",
      "attachments": [
        docx.getAs(MimeType.MICROSOFT_WORD),
        file2pdf
      ]
    })
  }
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67470893

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档