最近,我一直在进行一项调查。我开始在Excel Forms Online中创建它,但在我意识到它的一些缺点后切换到Google Forms。我遇到了一些障碍,但我以为我已经准备好了。
不幸的是,我开始在表单中添加问题并更改响应(拼写错误等等),这开始引发一大堆问题。如果适用的话,我必须回去询问用户对新问题的回答。更糟糕的是,我根本无法修改提交内容。我无法编辑连接到表单的电子表格,因为结果存储在表单中。如果我重新生成电子表格,那么表单中提交的响应将替换之前的响应。所以我根本无法编辑电子表格。
我一直在寻找一种尝试手动编辑用户提交的回复的方法。我找到了资源here on Stack Overflow和here on Google Groups at the Products Forum,但遗憾的是,我尝试了所有示例,但没有一个有效(是的,我将表单的URL放入其中并替换了所有名称使用电子表格名称。)
填写完信息后,我继续收到的错误是TypeError: Cannot call method "getDataRange" of null. (line 8, file "Code")
。但是这张纸不是空的,我知道。
是否有其他方法可以使这项工作,或者更好的方式来编辑工作表回复?
现在执行此操作的唯一方法是手动返回并重新提交表单作为该用户。这是一种痛苦,因为它需要10分钟的复选框和复制粘贴。另外,昨晚我偶然跳过复制1个角色,现在我不得不重新做一遍。
从我在网上看到的情况来看,这可以做到,但我尝试过的任何工作都没有。该表格目前正在播放并立即接受回复。任何解决方案都是可以接受的,只要有一种方法可以使用脚本或其他工具编辑他们的回复,所以我不需要自己手动重新执行所有操作。
答案 0 :(得分:16)
code suggested here正如我刚刚在2017年2月13日尝试过的那样。
https://docs.google.com/ ... /形式/ d /的 1ZIrWiRZQrUsz1y8OBoeB7AtCOM4Ax4FxAQm8xAR1OYo 强> /编辑
使用以下内容替换Code.js
部分中显示的所有文字,在您编辑之后,将表单ID替换为下面的YOUR_FORM_ID_HERE。
function dumpEditResponseUrlsForYourForm() {
// Change this next line to use the id of your form
var myFormId = "YOUR_FORM_ID_HERE";
var form = FormApp.openById(myFormId);
var formResponses = form.getResponses();
for (var i = 0; i < formResponses.length; i++) {
var formResponse = formResponses[i];
Logger.log(formResponse.getEditResponseUrl());
}
}