gpt4 book ai didi

google-apps-script - 自定义函数不适用于 ArrayFormula

转载 作者:行者123 更新时间:2023-12-04 16:35:49 25 4
gpt4 key购买 nike

我关注了帖子 https://developers.google.com/apps-script/guides/sheets/functions

function DOUBLE(input) {
return input * 2;
}

并将非常简单的 DOUBLE 函数复制到我的应用程序脚本中。

=double(A1)

正在工作并将我的整数加倍在“A1”中但是当我用值填充 A 列时,比如

A1 = 2
A2 = 3
A3 = 4
....

然后在 B1 单元格中,我运行

=arrayformula(double(A1:A))

它返回错误“结果不是数字”,#NUM!

我不确定哪里出了问题。任何应用脚本专家都可以提供帮助吗?

谢谢

最佳答案

这个答案怎么样?

  • 例如,当使用=DOUBLE(A1) 时,DOUBLE(input)input 的值被检索为一个数字或字符串(在您的情况下,它是一个数字。)。
  • 例如,当使用=DOUBLE(A1:B1) 时,DOUBLE(input)input 的值被检索为二维数组。

需要在确认input是否为数组后进行计算。上面反射(reflect)的修改如下。

发件人:

return input * 2;

收件人:

return Array.isArray(input) ? input.map(function(e){return e.map(function(f){return f * 2})}) : input * 2;

注意事项:

当上面的修改示例使用“if”和“for循环”编写时,变成如下。

if (Array.isArray(input)) {
var result = [];
for (var i = 0; i < input.length; i++) {
var temp = [];
for (var j = 0; j < input[i].length; j++) {
temp.push(input[i][j] * 2);
}
result.push(temp);
}
return result;
} else {
return input * 2;
}

如果我误解了你的问题,我很抱歉。

关于google-apps-script - 自定义函数不适用于 ArrayFormula,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48537313/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com