Google脚本自定义函数 - 范围数组作为参数

时间:2017-03-16 14:26:45

标签: javascript arrays scripting google-sheets

我在Google Scripts中创建自定义函数相对较新。

我需要能够将一系列范围传递给一个函数。

如果我接近这个错误,请告诉我。

当我在Google表格中将其引用为=ConcatEach(["A1:A2","B1:B2"],"$"])时,我收到了一个解析错误(没有引号。)

(另外,这些值是任意的。我知道美元符号在值之前。)

无论如何,这就是我所拥有的:

 function ConcatEach(rangeString, concatString)
 {
  //var rangeString = ["A1:A2","B1:B2"];
  //var concatString = "$";

  var sheet = SpreadsheetApp.getActiveSpreadsheet();
  var rangeValues=[];
  for(i=0;i<rangeString.length;i++)
  {
    var range = sheet.getRange(rangeString[i]);
    rangeValues.push(range.getValues());
  }

  //Logger.log(rangeValues);

  for(i=0;i<rangeValues.length;i++)
  {
    for(j=0;j<rangeValues[i].length;j++)
    {
      if(rangeValues[i][j] != "")
      {
        rangeValues[i][j] = rangeValues[i][j] + concatString;
      }
    }
  }
  return rangeValues;
}

任何帮助都将非常感激!谢谢!

1 个答案:

答案 0 :(得分:1)

您可以使用逗号将rangeString作为字符串传递:

"A1:A2,B1:B2"

然后使用JavaScript String split() Method

var array =  rangeString.split(",");
Logger.log(array); // you'll get array ['A1:A2', 'B1:B2']