来自 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();
}
我已经从电子表格中以编程方式创建了一堆表单,并为每个表单绑定了一个响应触发器。填写表格后,我似乎无法弄清楚填写了哪个表格。
我试过了:
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
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();
}