来自 FormResponse 的表单标题

Form title from FormResponse

我已经从电子表格中以编程方式创建了一堆表单,并为每个表单绑定了一个响应触发器。填写表格后,我似乎无法弄清楚填写了哪个表格。

我试过了:

Event.source.getId() 

但是 returns 电子表格的 ID。我想获得表格的标题。

编辑:澄清

我是这样设置触发器的:

ScriptApp.newTrigger('responseTrigger').forForm(form)
 .onFormSubmit()
 .create();

当我尝试获得标题时:

function responseTrigger(e) {
  var source = e.source;
  var title = e.source.getTitle().
  Logger.log(title);
}

我收到以下错误:

Execution failed: TypeError: Cannot find function getTitle in object Spreadsheet.

这个怎么样?

如果要在提交表单时检索标题,可以使用以下脚本。

var title = e.source.getTitle()

如果您总是想检索标题,可以使用以下脚本。

var form = FormApp.openById( form ID );
var title = form.getTitle();

我终于解决了这个问题。

有个知道Google Scripts issue that is causing my problem. You would expect e.source.getID() to give you the form's ID, however it gives you the spreadsheet's ID. I found a 。您要做的是找到触发器的唯一 ID,并将其与所有项目触发器交叉引用,如下所示:

    function getFileByTriggerId(triggerId){
      var triggers = ScriptApp.getProjectTriggers();
      for(var i =0; i<triggers.length; i++){
       if(triggers[i].getUniqueId() == triggerId){
        return triggers[i].getTriggerSourceId();
    }
  }
}

然后在你的响应触发中你写:

function responseTrigger(e) {
  var realEvent = getFileByTriggerId(e.triggerUid);
  var form = FormApp.openById(realEvent);
  var title = form.getTitle();
}