如何使用公式获取每行中第一个非空单元格?例如下所示工作表,要求使用公式根据上半部分的表格求各项目的开工日期。

获取每行中第一个非空单元格

也就是说,要求出单元格区域B2:G6的每行中第一个非空单元格对应的B1:G1中的日期。

先不看答案,自已动手试一试。

公式思路

先找到该行中第1个非空单元格的位置,然后获取第1行B1:G1中该位置的值。

公式

在单元格B9中的数组公式如下:

=IF(COUNTA(B2:G2),INDEX($B$1:$G$1,MATCH(TRUE,B2:G2<>””,0)),””)

结果如所示。

获取每行中第一个非空单元格

公式解析

首先,公式:

MATCH(TRUE,B2:G2<>””,0)

找出第2行单元格区域B2:G2中第1个非空单元格的位置,本例中为1。

然后,将该值代入INDEX函数,即变成公式:

INDEX($B$1:$G$1,1)

得到单元格B1,即对应的第1行中B1:G1的值。

将该值代入后的公式:

=IF(COUNTA(B2:G2),B1,””)

然后,根据COUNTA函数的值来判断公式最后的值。

因为本例中B2:G2包含文本,因此最后的结果即为单元格B1中的值。

将该公式下拉至单元格B13,即可求出各项目对应的开工时间。

小结

使用MATCH函数找到位置,使用INDEX函数获取相应位置的数据

使用<>””来生成代表空与非空单元格的数组。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。