我希望第二只眼睛能看到我剧本中相当简单的部分。这个脚本在每次提交响应时都会被触发,它所做的就是获取一列数据,该列包含一个标识的文本字符串,并将其转换为一个超链接来编辑特定的响应。但是,由于某种原因,超链接引用的是不正确的响应。更奇怪的是,每次提交回复时,偏移量都会增加1。
原始
1次提交后的
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 + '")');
} 发布于 2014-11-10 18:09:16
作为一种修正,我基本上使用了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);https://stackoverflow.com/questions/26809415
复制相似问题