You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

如何禁用ArrayFormula计算列名?谷歌表格Query公式报错解决

解决Google Sheets Query因列名与保留字冲突导致的#WAARDE!错误

我太懂你这个头疼的问题了——当你用Query函数处理包含OR这种和语法保留字重名的列时,Google Sheets会把列名OR误判成逻辑运算符OR,直接抛出#WAARDE!错误,之前的列名没踩中保留字所以一切正常,到OR列就翻车了。

问题本质

Google Sheets Query语法有一批保留关键字(比如ORANDSELECTWHERE),如果你的列名和这些关键字重名,直接引用会被Query当作语法规则解析,而非列名,这就是报错的核心原因。

核心解决方案:用反引号包裹列名

只需要在生成列名时,给每个列名前后加上反引号(`),明确告诉Query“这是列名,不是语法关键字”。

修改后的完整公式

把原公式中生成列名的部分加上反引号包裹,修改后的公式如下:

=arrayformula(query('Formulierreacties 1'!A1:RA; "Select " & join(","; "`"&SUBSTITUEREN(ADRES(1; KOLOM(A:G); 4); "1"; "")&"`") & ", " & join(","; "`"&SUBSTITUEREN(ADRES(1; KOLOM(MT:QP); 4); "1"; "")&"`") & " where G = 6002"))

关键修改说明

原公式里SUBSTITUEREN(ADRES(1; KOLOM(MT:QP); 4); "1"; "")会生成MTMUORQP这类列名,现在我们通过"``"&列名&"``"的方式,让每个列名都被反引号包裹,这样Query就能正确识别OR是列名而非逻辑运算符,自然就不会报错了。

验证小技巧

你可以单独测试列名生成部分,在空白单元格输入:

=join(","; "`"&SUBSTITUEREN(ADRES(1; KOLOM(MT:QP); 4); "1"; "")&"`")

查看输出是否为MT,MU,...,OR,...,QP,确认每个列名都被正确包裹反引号。

内容的提问来源于stack exchange,提问作者rpad2706

火山引擎 最新活动