我需要从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来做这个吗?

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


当前回答

是的,这是可能的。

如果满足条件,可以让公式返回true - blank。通过了ISBLANK公式的检验。唯一不方便的是,当条件满足时,公式将消失,您将不得不重新输入它。您可以设计一个公式,使其能够将结果返回给相邻的单元格,从而避免自毁。是的,这也是可能的。

你所需要的是设置一个命名范围,比如GetTrueBlank,然后你就可以像你的问题一样使用下面的模式:

=IF(A1 = "Hello world", GetTrueBlank, A1)

步骤1。把这段代码放到VBA的Module中。

Function Delete_UDF(rng)
    ThisWorkbook.Application.Volatile
    rng.Value = ""
End Function

步骤2。在Sheet1的A1单元格中,使用以下公式添加命名范围GetTrueBlank:

=EVALUATE("Delete_UDF("&CELL("address",Sheet1!A1)&")")

就是这样。没有进一步的步骤了。用自灭公式。在单元格B2中输入以下公式:

=IF(A2=0,GetTrueBlank,A2)

如果在A2中输入0,则B2中的上述公式将计算为trueblank。

您可以在这里下载演示文件。

在上面的示例中,将公式求值为trueblank会在空单元格中得到结果。用ISBLANK公式检查单元格的结果为TRUE。这是切腹自杀。当满足条件时,公式从单元格中消失。目标达到了,尽管您可能希望公式不要消失。

您可以修改公式以在相邻单元格中返回结果,这样公式就不会自行终止。查看如何在相邻单元格中获取UDF结果。

我在《the FrankensTeam》中看到了一个获得trueblank作为公式结果的例子: https://sites.google.com/site/e90e50/excel-formula-to-change-the-value-of-another-cell

其他回答

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

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

这就是我如何为我正在使用的数据集做的。这看起来既复杂又愚蠢,但它是学习如何使用上面提到的VB解决方案的唯一选择。

我“复制”了所有数据,并将数据粘贴为“值”。 然后我突出显示粘贴的数据,并使用一些字母“替换”(Ctrl-H)空单元格,我选择q,因为它不在我的数据表上的任何地方。 最后,我做了另一个“替换”,把q替换成什么都没有。

这三个步骤将所有的“空”单元格变成了“空白”单元格。我尝试通过简单地将空白单元格替换为空白单元格来合并步骤2和步骤3,但这并不管用——我必须将空白单元格替换为某种实际文本,然后将该文本替换为空白单元格。

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

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

在IF语句中使用COUNTBLANK(B1)>0代替ISBLANK(B1)。

与ISBLANK()不同,COUNTBLANK()将""视为空并返回1。

这可以在Excel中完成,而不需要使用新的图表功能将#N/A设置为间隔。但它很精细。假设你想在XY图上画一条线。然后: 第一行,第1点 第二行,第2点 第三行:硬空 第四行,第二点 第五行,第3点 第6行:硬空 第七行,第3点 第八行,第4点 第9行:硬空 等

结果是有很多独立的行。这些点的公式可以控制是否被#N/ a省略。通常将公式中的点INDEX()放入另一个范围。