DriveApp.getFileById()奇怪的行为

时间:2018-09-11 14:56:47

标签: google-apps-script google-drive-api google-docs

代码仍处于概念验证阶段-将尝试解释预期的结果以及我得到的结果。

此脚本将是常规邮件合并。 该脚本应执行以下操作:

  • 提示用户输入要使用的模板文件的ID。 (Google文档文档)
  • 制作模板副本,并更改​​模板副本正文中的值。
  • 获取模板的编辑副本,并将其附加到电子邮件中。
  • 对电子表格中的每一行执行一次。

尽管上面的所有方法都运行良好,但是在附加模板的编辑副本时却出现了奇怪的现象。而不是获得模板的编辑版本,而是获得电子邮件所附模板的未编辑版本

function myFunction() {


var ui = SpreadsheetApp.getUi();
var response = ui.prompt('Please enter the ID of your template file.', ui.ButtonSet.OK_CANCEL);

if(response.getSelectedButton() == ui.Button.OK){
var templateid = response.getResponseText()
}//End of IF Statement

var docid = DriveApp.getFileById(templateid).makeCopy().getId();
var doc = DocumentApp.openById(docid);
var body = doc.getBody();

var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var lastColumn = sheet.getLastColumn();

sheet.getRange(1, 1, sheet.getLastRow(), sheet.getLastColumn()).setNumberFormat("@");


var array = [];

for(var i = 1; i < lastColumn-1; i++) {
var headers = sheet.getRange(1, i, 1, 1).getValue();
array.push(headers)
}//END OF OUTER 1

for (var k = 2; k < sheet.getLastRow()+1; k++){
var row = sheet.getRange(k, 1, 1, lastColumn).getValues()

for (var j = 0; j <array.length; j++){
body.replaceText("<"+array[j]+">", row[0][j]);
}//END OF INNER


var recipient = sheet.getRange(k, lastColumn - 1, 1, 1).getValue();
var emailBody = "Good Day,\n\nPlease see attatched.\n\nRegards\nPerson's Name Here"
var subject = "See attatched";
var attatchment = DriveApp.getFileById(doc.getId());

Logger.log(doc.getId())


MailApp.sendEmail(recipient, subject, emailBody, {attachments: attatchment})

}//END OF OUTER 2
}//END OF FUNCTION

使用的电子表格:

enter image description here

预期结果:

enter image description here

实际结果:

enter image description here

1 个答案:

答案 0 :(得分:2)

在您的脚本中,我认为可能需要使用saveAndClose()。因此,例如,请在脚本中,如下所示将其添加到var attatchment = DriveApp.getFileById(doc.getId());之前。

var subject = "See attatched";
doc.saveAndClose(); // Added
var attatchment = DriveApp.getFileById(doc.getId());

参考:

其他信息:

在DocumentApp,SpreadsheetApp和SlidesApp的类中,当通过每个类的方法修改Doc时,如果脚本正在运行,则通过使用save方法保存Doc来反映修改。另一方面,在Google APIs Sheets API和Slides API中,调用并运行每种方法时,即使脚本正在运行,也会反映出修改。在Google文档中,还没有文档API。但是最近,the form about the early access of Docs API被发布了。当能够使用Docs API时,我认为API的方法可能无需使用saveAndClose()就可以编辑和保存文档。