响应循环保持转移

时间:2014-11-07 20:18:12

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

我希望在我的剧本的一个相当简单的部分得到第二双眼睛。每次提交响应时都会触发此脚本,它所做的只是获取一列数据,其中包含一个标识的文本字符串,并将其转换为超链接以进行编辑该特定响应。但是出于某种原因,超链接引用了错误的响应。更奇怪的是,每次提交回复时,偏移量都会增加1.以下是一个例子:

ORIGINAL

  • 条目1 - 超级链接进入条目1
  • 第2条 - 超链接进入第2条
  • 第3条 - 超级链接进入第3条
  • 条目4 - 超级链接进入条目4

1提交后

  • 条目1 - 超级链接进入条目2
  • 第2条 - 超链接进入第3条
  • 第3条 - 超级链接进入第4条
  • 条目4 - 超级链接进入条目1

2次提交后

  • 条目1 - 超级链接进入条目3
  • 第2条 - 超级链接进入第4条
  • 条目3 - 超级链接进入条目1
  • 第4条 - 超级链接进入第2条

以下是我用来生成超链接的代码:

var _sht = SpreadsheetApp.openById("XXX").getSheetByName("Sheet");
var formID = "YYY";
var form = FormApp.openById(formID);
var formResponses = form.getResponses();

for (var ii=0; ii<formResponses.length; ii++) {
  var tradeName = _sht.getRange(ii+2, 2).getValue();
  _sht.getRange(ii+2, 2).setFormula('=HYPERLINK("' + formResponses[ii].getEditResponseUrl() + '","' + tradeName + '")');
}  

1 个答案:

答案 0 :(得分:0)

作为修复,我基本上使用了AD的修改版本:AM的答案位于here。我的修改包括添加一个额外的数组来捕获每个响应的第二个问题的答案,并将其用作超链接的标题。这是为了保持工作表清洁 - 而不是使用具有长超链接的附加列,它只是用启用超链接的版本替换现有数据。

var tradeCol = 2, timeCol = 4;  
var data = _sht.getDataRange().getValues();
var timestamps = [], urls = [], trades = [], resultUrls = [];

for (var i=0; i<formResponses.length; i++) {
  timestamps.push(formResponses[i].getTimestamp().setMilliseconds(0));
  urls.push(formResponses[i].getEditResponseUrl());
  trades.push(formResponses[i].getItemResponses()[1].getResponse());
}

for (var j=1; j<data.length; j++) {
  resultUrls.push([
    data[j][timeCol-1]?
    '=HYPERLINK("' + urls[timestamps.indexOf(data[j][timeCol-1].setMilliseconds(0))] + '","' + trades[timestamps.indexOf(data[j][timeCol-1].setMilliseconds(0))] + '")':
    '']);
}

_sht.getRange(2, tradeCol, resultUrls.length).setFormulas(resultUrls);