对于在Google脚本中创建自定义函数,我还比较陌生。

我需要能够将范围数组传递给函数。

如果我处理方法不正确,请通知我。

在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;
}


任何帮助将不胜感激!谢谢!

最佳答案

您可以将rangeString作为带有逗号的字符串传递:

"A1:A2,B1:B2"


然后使用JavaScript String split() Method

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

09-26 02:34