如何获取行中的所有非空单元格数据 - Google表格脚本编辑器

时间:2018-01-02 02:46:03

标签: google-sheets scripting cell google-sheets-api google-apps-script-editor

我不确定这是否可能,而且说实话,我没有尝试过很多东西,因为我不确定从哪里开始。我正在使用Google表格中的脚本编辑器,顺便说一句。我知道有SpreadsheetApp.getRange()和另一个获取值或类似的东西。但我想要的是有点具体。

有没有办法获取给定行中的所有单元格数据并将其放入数组中?行的大小会有所不同,这就是我无法做到确切范围的原因。

例如,如果我要让行具有以下值:

abc | 123 | 987 | efg
blah| cat | 654

我希望能够获取这些值并将它们放入像[“abc”,“123”,“987,”efg“]这样的数组中。然后,如果我在下一行运行该函数,它就会' d是[“blah”,“cat”,“654”]。

实际上,只要有能够使用的分隔符,它就可以放入任何数据类型。

提前谢谢!

3 个答案:

答案 0 :(得分:3)

这对你有用吗?

当第1行,第2行和第3行,abc | 123 | 987 | efgblah| cat | 654abc | | 987 | efgmyFunction(1)myFunction(2)myFunction(3)时返回[abc, 123.0, 987.0, efg][blah, cat, 654.0][abc, , 987.0, efg]

function myFunction(row){
  var ss = SpreadsheetApp.getActiveSheet();
  var values = ss.getRange(row, 1, 1, ss.getLastColumn()).getValues();
  var c = 0;
  for (var c = values[0].length - 1; c >= 0; c--){
    if (values[0][c] != "") break;
  }
  values[0].splice(c + 1, values[0].length - c - 1);
  return values[0];
}

答案 1 :(得分:2)

改编自https://developers.google.com/apps-script/reference/spreadsheet/sheet#getDataRange()

如果你想要一个数组,你可以直接循环和创建你的数组。这里我将说明为所有行创建,但是如果你知道你想要的行,你可以不用外部循环(只需将i设置为所需的行)。

`function rowArr() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
 var sheet = ss.getSheets()[0];

 // This represents ALL the rows
 var range = sheet.getDataRange();
 var values = range.getValues();
 for (var i = 0; i < values.length; i++) {
   var row = [];
   for (var j = 0; j < values[i].length; j++) {
     if (values[i][j]) {
       row.push(values[i][j]);
     }
   }
   Logger.log(row);
 }


}`

答案 2 :(得分:1)

如果没有脚本,这更容易实现,公式=filter(1:1, len(1:1))返回第1行中非空单元格中的所有值,等等。

从脚本中,您可以执行以下操作:

function flat_nonempty() {
  var range = SpreadsheetApp.getActiveSheet().getRange("A:A"); // range here
  var values = range.getValues();
  var flat = values.reduce(function(acc, row) {
    return acc.concat(row.filter(function(x) {
      return x != "";
    }));
  }, []);
  Logger.log(flat); // flat list of values, no blanks
}

此处的范围可以有一行或多行。