对于在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']