我需要从Excel公式返回一个空单元格,但Excel似乎将空字符串或空单元格引用与真正的空单元格区别对待。所以本质上我需要

=IF(some_condition,EMPTY(),some_value)

我试着去做一些事情

=IF(some_condition,"",some_value)

and

=IF(some_condition,,some_value)

假设B1是空单元格

=IF(some_condition,B1,some_value)

但这些似乎都不是真正的空单元格,我猜是因为它们是公式的结果。是否有办法填充一个细胞当且仅当满足某些条件,否则保持细胞真正空?

编辑:按照建议,我尝试返回NA(),但对于我的目的,这也不工作。有办法用VB来做这个吗?

编辑:我正在构建一个工作表,它从其他工作表中拉入数据,这些工作表被格式化为将数据导入数据库的应用程序的非常特定的需求。我没有权限更改此应用程序的实现,如果值为“”而不是实际为空,则会失败。


当前回答

哇,很多人误解了这个问题。很容易让一个单元看起来是空的。问题是,如果您需要单元格为空,Excel公式不能返回“无值”,而只能返回一个值。返回零、空格甚至“”都是一个值。

因此,您必须返回一个“魔法值”,然后使用搜索和替换或使用VBA脚本将其替换为无值。虽然你可以使用空格或“”,但我的建议是使用一个明显的值,比如“NODATE”或“NONUMBER”或“XXXXX”,这样你就可以很容易地看到它出现在哪里——在电子表格中很难找到“”。

其他回答

我去掉了单引号,这样+1-800-123-4567这样的电话号码列就不会产生计算结果并产生负数。 我尝试了一个黑客删除他们的空单元格,酒吧引用,然后击中这个问题也(列F)。它更容易只是在源单元格上调用文本,瞧!:

=IF(F2="'","",TEXT(F2,""))

我使用了下面的工作使我的excel看起来更干净:

当你进行任何计算时,""会给你错误所以你想把它当作一个数字所以我使用了一个嵌套的if语句来返回0而不是""如果结果是0这个方程将返回""

=IF((IF(A5="",0,A5)+IF(B5="",0,B5)) = 0, "",(IF(A5="",0,A5)+IF(B5="",0,B5)))

这样excel表格看起来会很干净。

如果目标是能够在单元格值为0时将其显示为空,则不使用导致单元格为空或空的公式(因为没有empty()函数),

你想要一个空白单元格,返回一个0而不是“”然后 像这样设置单元格的数字格式,在这里您必须提出您想要的正数和负数(前两项由分号分隔)。在我的例子中,我拥有的数字是0、1、2……我希望0显示为空。(我从来没有弄清楚文本参数的用途,但它似乎是必需的)。 0, 0, ";“文本”@

Excel没有办法做到这一点。

Excel单元格中的公式的结果必须是数字、文本、逻辑(布尔)或错误。没有公式单元格值类型为“空”或“空白”。

我所看到的一个实践是使用NA()和ISNA(),但这可能也可能不能真正解决你的问题,因为其他函数处理NA()的方式有很大的不同(SUM(NA())是#N/ a,而SUM(A1)如果A1为空则为0)。

也许这是作弊,但很有效!

我还需要一个表作为图形的源,我不希望任何空白或零单元格在图形上产生一个点。的确,您需要设置图形属性,选择数据,隐藏和空单元格以“显示空单元格为间隙”(单击单选按钮)。这是第一步。

然后,在单元格中,可能会以不希望绘制的结果结束,将公式放在带有NA()结果的IF语句中,如=IF($A8>TODAY(),NA(), *formula to be *)

当出现无效的单元格值时,这将给出没有点的所需图形。当然,这使得所有具有无效值的单元格都要读取#N/A,这很混乱。

To clean this up, select the cell that may contain the invalid value, then select conditional formatting - new rule. Select 'format only cells that contain' and under the rule description select 'errors' from the drop down box. Then under format select font - colour - white (or whatever your background colour happens to be). Click the various buttons to get out and you should see that cells with invalid data look blank (they actually contain #N/A but white text on a white background looks blank.) Then the linked graph also does not display the invalid value points.