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

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


当前回答

尝试使用LEN计算单元格。如果它包含公式,LEN将返回0。如果它包含文本,则返回大于0。

其他回答

谷歌带着一个非常相似的问题来到这里,我终于找到了一个适合我需要的解决方案,它可能也会帮助其他人…

我用了这个公式:

=IFERROR(MID(Q2, FIND("{",Q2), FIND("}",Q2) - FIND("{",Q2) + 1), "")

这个答案并没有完全解决OP,但我已经有几次遇到类似的问题,并寻找答案。

如果您可以根据需要重新创建公式或数据(从您的描述中看起来似乎可以),那么当您准备好运行需要空白单元格实际为空的部分时,您可以选择该区域并运行以下vba宏。

Sub clearBlanks()
    Dim r As Range
    For Each r In Selection.Cells
        If Len(r.Text) = 0 Then
            r.Clear
        End If
    Next r
End Sub

这将清除当前显示“”或只有公式的任何单元格的内容

是的,这是可能的。

如果满足条件,可以让公式返回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

Excel没有办法做到这一点。

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

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

到目前为止,这是我能想到的最好的。

它使用ISBLANK函数来检查if语句中的单元格是否真的为空。 如果单元格中有任何内容(本例中的A1),甚至是一个空格字符,则该单元格不为EMPTY,计算将得到结果。 这将防止计算错误显示,直到你有数字工作。

如果单元格为EMPTY,则计算单元格将不显示计算中的错误。如果单元格不为空,则将显示计算结果。 如果您的数据是坏的,这将抛出一个错误,可怕的#DIV/0!

=IF(ISBLANK(A1)," ",STDEV(B5:B14))

根据需要更改单元格引用和公式。