首页 > Excel专区 > Excel函数 >

利用count+find函数嵌套 统计excel单元格中不重复的数字个数

Excel函数 2023-01-08

具体操作如下:

直接在下图C4单元格,输入如下公式:

=COUNT(FIND(ROW($A$1:$A$11)-1,B4))

注意公式中A1:A11的范围正好是1-11这个数值范围。为什么呢?

 

输入该公式后,需要按住Ctrl+Shift,然后在敲击“Enter回车键”即可。(Ctrl+Shift+enter是数组公式的录入按键),敲击完成后,注意公式会前后两段加上大括号{}。(下图箭头处)大括号是说明该公式为数组公式。

 

输入完毕后,双击C4单元格右下角的数据填充柄(上图箭头1所示),即可完成公式复制,算出每行B列彩票的不重复的数字个数。大家可以验证一下这个数值是否正确。

 

我们需要搞清楚这个公式的用意,才能做到举一反三。

=COUNT(FIND(ROW($A$1:$A$11)-1,B4))

上面这个公式用了三个函数,先来看看ROW函数。

ROW返回单元格所在的行数,举例如下,求B25单元格所在的行数,那肯定是25。

 

那ROW($A$1:$A$11)是什么鬼?

如果你输入进去试试,你会发现行数为1.效果如下图:

 

也就是说ROW正常情况下只取第一个单元格的行数,那为什么要选择区域呢?主要为了数组公式配合。那是数值公式,简单的讲就是按数据区域(面)来进行统计的方式。如果按照数组的思路,那么ROW(A1:A11),就能统计出A1到A11单元格每一行的行数,即1,2,3,4,5,6,7,8,9,10,11。

那ROW($A$1:$A$11)-1,是什么就是每一行都减去1行,就变成0,1,2,3,4,5,6,7,8,9,10。其实这个函数主要为了产生1-10的一个数字。

接下来学习一下FIND函数。FIND函数主要是取得某个数在某个单元格的开始位置。举例如下:

比如要找6这个数字在B4单元格中数值的位置,返回是4。表明6在9376343这个数字的从左往右数是第四个。

 

FIND(ROW($A$1:$A$11)-1,B4)

那么把ROW嵌套到FIND里面,无非就是为了告诉FIND,要找0,1,2,3,4,5,6,7,8,9,10在单元格中的位置。如果这个数字有,就会返回一个位置数字。 
 

=COUNT(FIND(ROW($A$1:$A$11)-1,B4))

而在外面在套一个count函数,就是对有位置的数字进行计数统计,从而算出不重复的数字的个数。牛闪闪用“公式求值功”能来追踪一下,

选中下图C4单元格,点击“公式—公式求值”,在新弹窗口中点击“求值”,就可以进行逐步运算。

 

看,分别寻找0-10,在B4中的位置,分别返回位置数。

 

在继续点求值,就会出下下图效果,可以看到0,1,2在9376343中没有,所以是#value!(错误值)。3在9376343中为第二位,所以返回是2,4在在9376343中为第六位,所以是6,以此类推算出能在9376343找到的数字的位数。

 

最后利用count函数的特性,只统计数字的个数,自动忽略错误值,所以算出不重复的数字的个数。如下图所示:

 

如果你理解的话,你会发现上面的公式写得不是那么完美,其实只要判断0-9的数字就可以了,干嘛要到10呢。所以把公式改改:把A1:A11改成A1:A10也是可以的,记住将光标停在编辑栏,在按Ctrl+Shift+enter键进行公式录入,才有效。

 

甚至可以直接改成数组的写法,记得用大括号括起来,这样直接敲回车enter就可以录入公式。


Copyright © 2016-2023 office学习教程网 office.tqzw.net.cn. All Rights Reserved.