我在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;
}
任何帮助都将非常感激!谢谢!
答案 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']