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

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


当前回答

如果您正在使用HLOOKUP和VLOOKUP等查找函数将数据带入工作表,请将函数放在括号内,函数将返回一个空单元格而不是{0}。例如,

如果查找单元格为空,将返回零值:

    =HLOOKUP("Lookup Value",Array,ROW,FALSE)

如果查找单元格为空,则返回空单元格:

    =(HLOOKUP("Lookup Value",Array,ROW,FALSE))

我不知道这是否适用于其他功能……我还没试过。我使用Excel 2007来实现这一点。

Edit

为了让IF(A1="",,)返回为真,需要在同一个单元格中用&分隔两次查找。解决这个问题的简单方法是使第二个查找单元格位于行的末尾,并且始终为空。

其他回答

这个答案并没有完全解决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

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

如果您正在使用HLOOKUP和VLOOKUP等查找函数将数据带入工作表,请将函数放在括号内,函数将返回一个空单元格而不是{0}。例如,

如果查找单元格为空,将返回零值:

    =HLOOKUP("Lookup Value",Array,ROW,FALSE)

如果查找单元格为空,则返回空单元格:

    =(HLOOKUP("Lookup Value",Array,ROW,FALSE))

我不知道这是否适用于其他功能……我还没试过。我使用Excel 2007来实现这一点。

Edit

为了让IF(A1="",,)返回为真,需要在同一个单元格中用&分隔两次查找。解决这个问题的简单方法是使第二个查找单元格位于行的末尾,并且始终为空。

答案是肯定的——你不能使用=IF()函数而让单元格空着。"看起来空"和"空"不一样。遗憾的是,背靠背的两个引号没有产生一个空的单元格,否则公式就会消失。

如果您像我一样,在一个空单元格后,以便单元格中的文本可以溢出到相邻的单元格,则返回“”,但将单元格格式的文本方向设置为旋转5度。如果向左对齐,您会发现这会导致文本溢出到相邻的单元格,就好像该单元格是空的一样。

参见before和after:

=IF(RANDARRAY(2,10,1,10,TRUE)>8,"abcdefghijklmnopqrstuvwxyz","")

请注意,空单元格不是空的,而是包含“”,但文本仍然可以溢出。

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

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

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