如何在Google表格/表格中修改表单提交的响应?

时间:2016-06-11 21:52:36

标签: google-apps-script google-sheets google-form editing

最近,我一直在进行一项调查。我开始在Excel Forms Online中创建它,但在我意识到它的一些缺点后切换到Google Forms。我遇到了一些障碍,但我以为我已经准备好了。

不幸的是,我开始在表单中添加问题并更改响应(拼写错误等等),这开始引发一大堆问题。如果适用的话,我必须回去询问用户对新问题的回答。更糟糕的是,我根本无法修改提交内容。我无法编辑连接到表单的电子表格,因为结果存储在表单中。如果我重新生成电子表格,那么表单中提交的响应将替换之前的响应。所以我根本无法编辑电子表格。

我一直在寻找一种尝试手动编辑用户提交的回复的方法。我找到了资源here on Stack Overflowhere on Google Groups at the Products Forum,但遗憾的是,我尝试了所有示例,但没有一个有效(是的,我将表单的URL放入其中并替换了所有名称使用电子表格名称。)

填写完信息后,我继续收到的错误是TypeError: Cannot call method "getDataRange" of null. (line 8, file "Code")。但是这张纸不是空的,我知道。

是否有其他方法可以使这项工作,或者更好的方式来编辑工作表回复?

现在执行此操作的唯一方法是手动返回并重新提交表单作为该用户。这是一种痛苦,因为它需要10分钟的复选框和复制粘贴。另外,昨晚我偶然跳过复制1个角色,现在我不得不重新做一遍。

从我在网上看到的情况来看,这可以做到,但我尝试过的任何工作都没有。该表格目前正在播放并立即接受回复。任何解决方案都是可以接受的,只要有一种方法可以使用脚本或其他工具编辑他们的回复,所以我不需要自己手动重新执行所有操作。

1 个答案:

答案 0 :(得分:16)

code suggested here正如我刚刚在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网页中的“查看|日志”。它会弹出一个窗口,其中包含指向表单回复的链接。