COUNTIF函数在文本排序中的应用
我们知道,COUNTIF函数通常用于查找指定单元格区域中满足条件的单元格数量。然而,COUNTIF函数有一个比较有用的用法,它可以统计指定区域中大于或小于指定值的单元格数量。例如,公式:
COUNTIF({a,b,c,d,e,f,g,h},”<c”)
返回值2,表示数组中比c小的字母有2个,那么如果由小到大排的话,c应该排在第3位。
因此,使用COUNTIF函数,我们可以找到单元格区域中任意单元格中值的顺序。当我们知道这些顺序后,就可以使用VLOOKUP函数来查找对应的单元格中的值,从而实现按顺序对这些单元格中的值排序。
简单地说,使用COUNTIF函数,我们可以对单元格区域中的文本排序。
如下所示,在单元格B6中,使用公式:
=COUNTIF($C$6:$C$15,”<=”&C6)
得到单元格C6中的文本在单元格区域C6:C15的文本中,由小到大排在第10位。
将公式下拉至单元格B15,得到相应的列C中文本在单元格区域C6:C15中文本的排序位置。
在单元格E6中的公式为:
=VLOOKUP(ROW()-ROW($E$5),$B$6:$C$15,2,FALSE)
其中,ROW()-ROW($E$5)的值为1,即查找单元格区域B6:C15中列B中的值为1对应的列C中单元格的值,也就是单元格区域C6:C15中最小的文本。
将该公式向下拉至单元格E15,得到排序好的文本。当将公式向下拉时,随着行的变化,ROW()-ROW($E$5)的值也不断变化,从而取得相应的值。
注意,如果担心“顺序号”列中有重复值,可以使用公式:
=VLOOKUP(SMALL($B$6:$B$15,ROW()-ROW($E$5)),$B$6:$C$15,2,FALSE)
上面的列B实际上是我们使用的辅助列,这样使整个运算过程更清楚。其实,可以不使用辅助列,直接使用一个数组公式。在单元格E6中输入数组公式:
=VLOOKUP(ROW()-ROW($E$5),CHOOSE({1,2},COUNTIF($C$6:$C$15,”<=”& $C$6:$C$15),$C$6:$C$15),2,0)
下拉至单元格E15,得到同样的结果。
最新推荐
-
win7如何设置局域网工作机组 win7局域网共享设置工作组
win7如何设置局域网工作机组?win7是一个很经典的电脑操作系统,至今还有大量用户都在使用,在使用过程中 […]
-
win7如何添加自带游戏 win7自带游戏怎么恢复
win7如何添加自带游戏?在win7系统中,自带了很多经典的系统游戏,但是有的用户找不到这些小游戏,那要怎 […]
-
win11用户账户控制怎么取消 win11关闭uac方法
win11用户账户控制怎么取消?在win11系统中,用户帐户控制 (UAC) 可以防止对 Windows […]
-
win10怎么查看网口是百兆千兆还是千兆 电脑网口是百兆还是千兆
win10怎么查看网口是百兆千兆还是千兆?电脑的网口速率,影响着电脑上传下载的速度,但是很多用户都不清楚自 […]
-
系统edge浏览器按f12打不开开发者工具怎么办 edge打不开开发者模式
系统edge浏览器按f12打不开开发者工具怎么办?edge浏览器是windows系统自带的浏览器,在使用E […]
-
Win11文件夹无法取消只读怎么办 文件夹无法取消只读属性
Win11文件夹无法取消只读怎么办?在最新的win11系统中,很多用户都发现自己在进行文件夹权限设置的时候 […]
热门文章
win7如何设置局域网工作机组 win7局域网共享设置工作组
2win7如何添加自带游戏 win7自带游戏怎么恢复
3win11用户账户控制怎么取消 win11关闭uac方法
4win10怎么查看网口是百兆千兆还是千兆 电脑网口是百兆还是千兆
5系统edge浏览器按f12打不开开发者工具怎么办 edge打不开开发者模式
6Win11文件夹无法取消只读怎么办 文件夹无法取消只读属性
7win11下载软件安装不了怎么办 win11安装软件被阻止弹出提示
8yuzu模拟器pc版怎么安装 yuzu模拟器电脑安装教程
9win10玩cf两边有黑边如何改 win10玩cf全屏显示不全
10yuzu模拟器怎么添加游戏 yuzu模拟器添加游戏详细步骤
随机推荐
专题工具排名 更多+