Javascript 二维数组到二维数组

Javascript 2D Array to two-2D Arrays

我在 Google Apps 脚本中。我从 spreadsheet, "Documents" 中获取了所有的 dta。顶行是“字母”、“”、“模板”、“”。第 1 列具有人类可读的文档描述(例如“致客户的信”)。第 2 列具有模板的 Google 个文档 ID。第 3 列返回到备忘录的人类可读描述,第 4 列具有模板的 Google 个文档 ID。

我的目标是将由此 sheet 生成的数组分成两个单独的数组,这样 var larray = ["letter to client", "docID"] (依此类推;大约有 10 个行字母和 7 行备忘录)。我需要能够解决,例如 larray[4][1] 和 return docID。

这是我的脚本,但现在我只获得一维数组,而不是二维数组。我缺少什么来强制 larray 进入 2d?

function testArray(){
  var data = ssAF.getSheetByName('Documents').getDataRange().getValues();
  var larray = [];
  var marray = [];
  for(var i = 0; i < data.length; i++){
    if(data[0][i] == "Letters"){
      for (var j = 0; j < data.length; j++) {
        if (data[j][i] != "") {
          larray.push(data[j][i], data[j][i+1])
        }
      }
    }
    else if (data[0][i] == "Memoranda"){
      for (var j = 0; j < data.length; j++) {
        if (data[j][i] != "") {
          marray.push(data[j][i]);
        }
      }
    }
  }
}

描述

如果 larray = [],larray.push(a,b) 将生成一维数组 [a,b]。 larray.push(c,d) 变为 [a,b,c,d]。要制作二维数组,请使用 larray.push([a,b]),现在 larray 为 [[a,b]]。 larray.push([c,d]) 变为 [[a,b],[c,d]]

脚本

function testArray(){
  var data = ssAF.getSheetByName('Documents').getDataRange().getValues();
  var larray = [];
  var marray = [];
  for(var i = 0; i < data.length; i++){
    if(data[0][i] == "Letters"){
      for (var j = 0; j < data.length; j++) {
        if (data[j][i] != "") {
          larray.push([data[j][i], data[j][i+1]])
        }
      }
    }
    else if (data[0][i] == "Memoranda"){
      for (var j = 0; j < data.length; j++) {
        if (data[j][i] != "") {
          marray.push([data[j][i]]);
        }
      }
    }
  }
}

参考