Javascript 谷歌电子表格排名值

Javascript 谷歌电子表格排名值,javascript,google-apps-script,google-sheets,Javascript,Google Apps Script,Google Sheets,我目前正在用谷歌电子表格建立一个决策矩阵,我想为结果实现一个排名功能。我不会这样做,如果只有4个选项,但在我的情况下,有大约32个选项可用 我试着用google脚本api实现这一点,但结果有点令人失望: function Ranking() { var sheet = SpreadsheetApp.getActiveSpreadsheet(); var alldata = sheet.getDataRange().getValues(); var data = []; var j = 8;

我目前正在用谷歌电子表格建立一个决策矩阵,我想为结果实现一个排名功能。我不会这样做,如果只有4个选项,但在我的情况下,有大约32个选项可用

我试着用google脚本api实现这一点,但结果有点令人失望:

function Ranking() {
var sheet = SpreadsheetApp.getActiveSpreadsheet();  
var alldata = sheet.getDataRange().getValues();
var data = [];
var j = 8;
for (var i = 0; i <= 31; i++) {
data [i] = alldata[18][j];
j= j+2;
}
var sorted = data.slice().sort(function(a,b){return b-a});
var ranks = data.slice().map(function(v){return sorted.indexOf(v)+1});
sheet.getRange("I20").setValue(ranks[0]);
sheet.getRange("K20").setValue(ranks[1]);
sheet.getRange("M20").setValue(ranks[2]);
sheet.getRange("O20").setValue(ranks[3]);
sheet.getRange("Q20").setValue(ranks[4]);
sheet.getRange("S20").setValue(ranks[5]);
sheet.getRange("U20").setValue(ranks[6]);
sheet.getRange("W20").setValue(ranks[7]);
sheet.getRange("Y20").setValue(ranks[8]);
sheet.getRange("AA20").setValue(ranks[9]);
sheet.getRange("AC20").setValue(ranks[10]);
sheet.getRange("AE20").setValue(ranks[11]);
sheet.getRange("AG20").setValue(ranks[12]);
sheet.getRange("AI20").setValue(ranks[13]);
sheet.getRange("AK20").setValue(ranks[14]);
sheet.getRange("AM20").setValue(ranks[15]);
sheet.getRange("AO20").setValue(ranks[16]);
sheet.getRange("AQ20").setValue(ranks[17]);
sheet.getRange("AS20").setValue(ranks[18]);
sheet.getRange("AU20").setValue(ranks[19]);
sheet.getRange("AW20").setValue(ranks[20]);
sheet.getRange("AY20").setValue(ranks[21]);
sheet.getRange("BA20").setValue(ranks[22]);
sheet.getRange("BC20").setValue(ranks[23]);
sheet.getRange("BE20").setValue(ranks[24]);
sheet.getRange("BG20").setValue(ranks[25]);
sheet.getRange("BI20").setValue(ranks[26]);
sheet.getRange("BK20").setValue(ranks[27]);
sheet.getRange("BM20").setValue(ranks[28]);
sheet.getRange("BO20").setValue(ranks[29]);
sheet.getRange("BQ20").setValue(ranks[30]);
sheet.getRange("BR20").setValue(ranks[31]);
}
函数排序(){
var sheet=SpreadsheetApp.getActiveSpreadsheet();
var alldata=sheet.getDataRange().getValues();
var数据=[];
var j=8;

for(var)i=0;i
for(i=0;iJason的答案很清楚且简短,但由于调用电子表格服务的次数太多,所以效率不高

有关此问题的背景信息,请参阅。您可能还想查看

您已经有了一个
列的数组
;如果您将其转换为一个二维数组,其中的值以行为单位,那么您可以在一个
setValues()
操作中将其全部写出

sheet.getRange("I20:BR20").setValues(transpose([ranks]));
这是一个转置函数,来自

迭代仍在进行,但它现在在转置函数中,而不是在
setValue()
调用中,因此这将运行得更快

sheet.getRange("I20:BR20").setValues(transpose([ranks]));
function transpose(a)
{
  return Object.keys(a[0]).map(function (c) { return a.map(function (r) { return r[c]; }); });
}