为每个受访者生成唯一的表单URL

时间:2015-11-07 21:11:24

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

我有一个Google Form使用Google电子表格存储回复。在我的电子表格中,我有4列:姓名,电子邮件,收入和第四列,Id,用于标识特定收件人。

我想要完成的是为每个受访者生成一个唯一的网址,以便他们可以回复表单使用相同的网址稍后编辑表单。

我查看了getEditUrl()(Google Apps脚本)方法,该方法在提交回复后为受访者创建了一个唯一的网址 - 以下代码:

function myFunction() {
  assignEditUrls();  
}

function assignEditUrls() {
  var form = FormApp.openById('1vsqvwomoqSXwF6TlNkmmktAAk2av2r-2LRrBYJdv3VQ');
    //enter form ID here

  var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Form Responses');

    //Change the sheet name as appropriate
  var data = sheet.getDataRange().getValues();
  var urlCol = 5; // column number where URL's should be populated; A = 1, B = 2 etc
  var responses = form.getResponses();
  var timestamps = [], urls = [], resultUrls = [];

  for (var i = 0; i < responses.length; i++) { 
    var resp = responses[i];

    timestamps.push(responses[i].getTimestamp().setMilliseconds(0));
    urls.push(shortenUrl(responses[i].getEditResponseUrl()));
    withItemResponse(responses[i])
  }
  for (var j = 1; j < data.length; j++) {
    var dop = data[j][0]

    resultUrls.push([data[j][0]?urls[timestamps.indexOf(data[j][0].setMilliseconds(0))]: '']);
  }
  sheet.getRange(2, urlCol, resultUrls.length).setValues(resultUrls);  
}


function shortenUrl(longUrl) {
  // google url shortener api key
  var key = "AIzaSyBVG4Q5i1mNI0YAO0XVGZ3suZU8etTvK34";

  var serviceUrl="https://www.googleapis.com/urlshortener/v1/url?key="+key;

  var options={
    muteHttpExceptions:true,
    method:"post",
    contentType: "application/json",
    payload : JSON.stringify({'longUrl': longUrl })
  };

  var response=UrlFetchApp.fetch(serviceUrl, options);

  if(response.getResponseCode() == 200) {
    var content = JSON.parse(response.getContentText());
    if ( (content != null) && (content["id"] != null) )
      return content["id"];
  }

  return longUrl;
}

但是我想以另一种方式做到这一点,即首先生成唯一的URL,然后发送给受访者,这样他们就可以提交和编辑他们的回复,而无需向他们发送另一个URL(例如editurlresponse )。

这可能吗?

1 个答案:

答案 0 :(得分:1)

最初发布到https://webapps.stackexchange.com/a/86399/88163

是的,这是可能的,但采用略有不同的方法:

为每位受访者提交一个答案,以便每个受访者获得一个编辑网址,然后将相应的网址发送给每位受访者。

下面是一个代码片段,它以编程方式提交响应并通过两个代码行记录一些响应属性,包括编辑响应URL,第一个有问题,第二个是解决方法。请注意,这些行使用getEditResponseUrl()而不是toPrefilledUrl()

它可以单独使用,也可以作为有限的脚本使用。

/*
This code shows how to get the edit response url of a 
programmatically submitted response to a Google Form
*/ 

// Replace the form ID by your own form
var formID = '1234567890abcdefghijklmnopqrstuvwxyz';

function myFunction() {
  var form = FormApp.openById(formID);
  var response = form.createResponse();
  var items = form.getItems();
  var item = items[0];
  if (item.getType() == 'TEXT') {
    var textItem = item.asTextItem();
    var itemResponse = textItem.createResponse('my text');
    response.withItemResponse(itemResponse);
  } 
  // Submit response
  var submittedResponse = response.submit();
  // Get submitted response attributes
  var values = {
    ID : submittedResponse.getId(),
    TS : submittedResponse.getTimestamp(),
    /* 
    Issue 4476: FormApp: getEditResponseUrl() produces invalid URL 
    https://code.google.com/p/google-apps-script-issues/issues/detail?id=4476
    */
    ER1 : submittedResponse.getEditResponseUrl(),
    /* Workaround from 
    https://code.google.com/p/google-apps-script-issues/issues/detail?id=4476#c2
    */
    ER2 : submittedResponse.getEditResponseUrl().replace(
      /\?edit2=.*/,"?edit2=" + submittedResponse.getId()
    ) 
  };
  Logger.log(values);
}

参考文献