XLSXWriter:具有= CONCAT的公式在Excel中显示为“ = @ CONCAT”吗?

问题描述

当我在XLSXWriter中执行以下操作时:

formula = "=CONCAT(A1,B1)"
worksheet.write_formula(1,1,formula)

...我在工作簿中找到以下内容:

=@CONCAT(A1,B1)

...并且该单元格显示一个#NAME错误。

我该如何纠正?

解决方法

Concat()仅在具有Office 2019或Office 365的Windows或Mac上可用。

任何其他版本的Excel都无法识别该功能,因此无法识别#Name!错误。

Concat()替换了Concatenate()函数。这些功能都不需要连接文本。 &运算符通常可以更快地完成工作,即键入的次数更少。若要更复杂,可以使用TextJoin()(仅限Office 365/2019)。

以下公式产生相同的结果。

=Concatenate(A1," - ",B1,C1)
=Concat(A1,C1)
=A1&" - "&B1&" - "&C1
=TEXTJOIN(" - ",TRUE,A1:C1)
,

问题在于CONCAT()函数是所谓的“未来函数”,已添加到最新版本的Excel中(请参阅XlsxWriter文档的Formulas added in Excel 2010 and later部分)。

您需要这样编写公式:

formula = "=_xlfn.CONCAT(A1,B1)"

但是,正如@teylyn指出的那样,还有许多其他更简单且向后兼容的方式在Excel中串联字符串。您应该改用其中一种。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...