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

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


当前回答

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

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

然后,在单元格中,可能会以不希望绘制的结果结束,将公式放在带有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.

其他回答

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

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

那么你必须使用VBA了。您将遍历范围内的单元格,测试条件,并删除匹配的内容。

喜欢的东西:

For Each cell in SomeRange
  If (cell.value = SomeTest) Then cell.ClearContents
Next

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

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

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

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

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

如此多的答案,返回一个值,看起来是空的,但实际上不是一个空的作为单元格请求…

如果您确实想要一个返回空单元格的公式。这是可能的通过VBA。这里是代码,可以做到这一点。首先编写一个公式,在您希望单元格为空的地方返回#N/ a错误。然后我的解决方案自动清除所有包含#N/A错误的单元格。当然,您可以根据自己的喜好修改代码以自动删除单元格的内容。

打开visual basic viewer (Alt + F11) 在项目资源管理器中找到感兴趣的工作簿并双击它(或右击并选择查看代码)。这将打开“视图代码”窗口。在(常规)下拉菜单中选择“工作簿”,在(声明)下拉菜单中选择“小型张计算”。

将以下代码(基于J.T. Grimes的回答)粘贴到Workbook_SheetCalculate函数中

    For Each cell In Sh.UsedRange.Cells
        If IsError(cell.Value) Then
            If (cell.Value = CVErr(xlErrNA)) Then cell.ClearContents
        End If
    Next

将文件保存为启用宏的工作簿

注:这个过程就像一把手术刀。它将删除任何计算为#N/A错误的单元格的全部内容,因此要注意。它们会消失,如果不重新输入它们曾经包含的公式,你就不能把它们拿回来。

NB2:很明显,当你打开文件时,你需要启用宏,否则它将无法工作,#N/A错误将保持未删除

我用的是一个小黑客。 我使用T(1),它返回一个空单元格。 T是excel中的一个函数,如果是字符串返回参数,否则返回空单元格。所以,你能做的是:

=IF(condition,T(1),value)