最近,我一直在进行一项调查。我开始在Excel Forms Online中创建它,但在我意识到它的一些缺点后切换到Google Forms。我遇到了几个障碍,但我以为我已经准备好了。
不幸的是,我开始在表单中添加问题并改变响应(拼写错误等等),这开始引发一大堆问题。如果适用的话,我必须回去询问用户对新问题的回答。更糟糕的是我无法修改提交内容。我无法编辑连接到表单的电子表格,因为结果存储在表单中。如果我重新生成电子表格,那么表单中提交的响应将替换之前的响应。所以我根本无法编辑电子表格。
我一直在寻找一种尝试手动编辑用户提交的响应的方法。我找到了一个资源 这里是Stack Overflow,和 这里是产品论坛上的Google网上论坛,但不幸的是,我尝试了所有的例子,但没有一个工作(是的,我把我的表格的URL放在一切,并用电子表格名称替换了名称)。
填写完我的信息后,我继续接收的错误是 TypeError: Cannot call method "getDataRange" of null. (line 8, file "Code")
。但是这张纸不是空的,我知道。
是否有其他方法可以使这项工作,或更好的方式来编辑工作表回复?
现在这样做的唯一方法是 手动 返回并重新提交表单 作为那个用户。这是一种痛苦,因为它是10分钟的复选框和复制和粘贴。另外,昨晚我不小心跳过复制1个角色,现在我不得不重新做一遍。
从我在网上看到的情况来看,这可以做到,但我尝试过的都没有。该表格目前正在接受并立即接受回复。任何解决方案都是可以接受的,只要有一种方法可以使用脚本或其他工具编辑他们的响应,所以我不需要自己手动重新执行所有操作。
该 代码在这里建议 工作,因为我自己在2017年2月13日尝试过。
以下是我使用此步骤的步骤
- 首先,加载表单,就像您要编辑表单一样。
- 在地址栏的网址中查找表单的“表单ID”。它应该看起来像这样:
https://docs.google.com/...
/形式/ d /1ZIrWiRZQrUsz1y8OBoeB7AtCOM4Ax4FxAQm8xAR1OYo/编辑
- 所以这个例子中的id就是“1ZIrWiRZQrUsz1y8OBoeB7AtCOM4Ax4FxAQm8xAR1OYo”
- 现在去 https://script.google.com
替换显示在中的所有文本 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());
}
}
- 点击Google Script网页中的“查看|日志”。它会弹出一个窗口,其中包含指向表单响应的链接。