响应循环不断变化
Loop for Responses Keeps Shifting
我希望对脚本中相当简单的部分有第二双眼睛。该脚本在每次提交响应时都会被触发,它所做的只是获取一列包含识别文本字符串的数据,并将其转换为超链接,以转到并编辑该特定响应。不过,由于某些原因,超链接引用了错误的响应。更奇怪的是,每次提交响应时,偏移量都会增加1。这里有一个例子:
原件
- 条目1-超链接转到条目1
- 条目2-超链接转到条目2
- 条目3-超链接转到条目3
- 条目4-超链接转到条目4
提交1次后
- 条目1-超链接转到条目2
- 条目2-超链接转到条目3
- 条目3-超链接转到条目4
- 条目4-超链接转到条目1
两次提交后
- 条目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 + '")');
}
作为修复程序,我基本上使用了位于此处的AD:AM答案的修改版本。我的修改包括添加一个额外的数组来捕捉每个回复的第二个问题的答案,并将其用作超链接的标题。这是为了保持工作表的整洁,而不是增加一个带有长超链接的列,它只是用启用超链接的版本替换现有数据。
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);
相关文章:
- jQuery:循环一个具有不同超时值的循环
- 在循环中分配json值时,值被覆盖
- 如何在下面的ES6循环中获得前面的文本
- 为什么“;未定义的“;在JavaScript中结束循环
- Javascript循环不会自我更新
- 如何使用jquery处理php循环通过元素
- 而循环只设置php中输入字段中的第一个值
- angularjs 无限$digest 当范围没有变化时循环
- 当循环条件在jQuery中发生变化时
- 摘要循环显示我的数组没有变化(视图不会刷新)
- 当javascript中的条件变量(全局变量)发生变化时,停止循环
- Firefox中的Angular2变化检测无限循环
- FB.Canvas.setAutoGrow()不起作用并创建高度变化的无限循环
- 按钮循环3个状态变化
- 如果element.getAttribute('class')发生变化,则退出嵌套for循环
- Angular不会识别forEach循环中的作用域变量变化
- Jquery循环插件,更新滑块在内容的变化,问题
- 角度 ui.router 无限循环$state或$location变化
- jQuery Load()会导致无限循环.SRC的变化
- 无限循环和不断变化的超时