Javascript Don';t将一个文件转换为PDF-Google应用程序脚本
我有下面这部分代码Javascript Don';t将一个文件转换为PDF-Google应用程序脚本,javascript,google-apps-script,google-apps,Javascript,Google Apps Script,Google Apps,我有下面这部分代码 doc.saveAndClose(); reportPDF = doc.getAs('application/pdf') reportPDF.setName('Doc1 - '+ rows[0][0] + ".pdf"); var file = destinationFolder.createFile(reportPDF); var folder = DriveApp.getF
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文档文件转换为Microsoft Word文件,必须使用导出链接
代码:
我希望这对你有帮助 答复:
要将Google文档文件转换为Microsoft Word文件,必须使用导出链接
代码:
我希望这对你有帮助 谢谢你@Rafa Guillermo!我将在这里尝试此代码。我能再问你一个问题吗?如果我只想在file1中使用Goolge文档文件而不是Microsoft Word文件,我使用与此代码相同的逻辑?要发送Google文档文件,您只需要文档文件的URL。类似于
doc.getUrl()
谢谢@Rafa Guillermo!我将在这里尝试此代码。我能再问你一个问题吗?如果我只想在file1中使用Goolge文档文件而不是Microsoft Word文件,我使用与此代码相同的逻辑?要发送Google文档文件,您只需要文档文件的URL。类似于doc.getUrl()
/**
* 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
]
})
}
}