如何解决不要将一个文件转换为 PDF - Google Apps 脚本 答案:代码:
我在下面有这部分代码
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? 我想像 Word 中的文档一样发送 Doc1,而 doc2 将保留为 pdf。
我正在考虑并进行一些测试(例如删除或尝试修改 reportPDF 部分),但我不知道是否有“更简单”的方法。
编辑:
创建文档的部分是:
const copy = googleDocTemplate.makeCopy('Metrics',destinationFolder);
const doc = DocumentApp.openById(copy.getId());
const body = doc.getBody();
解决方法
答案:
要将 Google Doc 文件转换为 Microsoft Word 文件,您必须使用导出链接。
代码:
/**
* 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
]
})
}
}
希望对你有帮助!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。