ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 36352|回复: 67

[原创] “万金油公式”思路解析

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2018-2-19 22:40 | 显示全部楼层 |阅读模式
Excel中有一个几乎“万能”的函数组合,在N多种问题的解决过程中都少不了她的身影,她就是Index+small+if+row组合!这个万金油的组合公式在日常工作中的应用非常广泛,今天通过一个例子的剖析,让大家了解公式的原理,遇到此类公式都可以自己进行套用。
很多朋友在Excel中用公式做查询的时候,都必然会遇到的一个麻烦问题,那就是一对多的查找问题,大多数朋友做查询都是从vlookup、index-match组合入门的,然而遇到一对多查询的时候,如果不加辅助列,往往会束手无策,今天我们要讨论的Index+small+if+row组合,就是专门解决一对多查询的一个通用公式。
好了,言归正传,先看一个效果图,到底一对多查询是怎样的:

1.gif
由动画演示可以看出,只要输入一个学号,就会根据学号在左边的成绩表中查询该学生的相关成绩。
得到这个查询结果,只用了一个数组公式:=IFERROR(INDEX($B$2:$D$28,SMALL(IF($A$2:$A$28=$H$2,ROW($1:$27),99),ROW(A1)),COLUMN(A1)),"")
除去IFERROR(排除错误显示)、COLUMN(多列引用)之外,就是今天要说的INDEX+SMALL+IF+ROW组合了。
公式有点长,下面咱们就一起来层层扒开,化繁为简,希望每个朋友都能够理解原理再加以应用。不过要想彻底理解这个公式,还得有一些储备知识,例如简单的数组应用,index、small、if和row这几个函数的基本用法也是要了解的。本文末尾会有相关链接,可以选择去复习。
先从index说起,这个函数基本功能是给出一个区域,然后根据对应的行列位置返回查找结果,本例中index查找的数据区域如下图所示。
无标题1.jpg
index一共需要三个参数,第一个参数是数据范围,刚才说了,第三个参数是要查找的内容位于这个范围的第几列,本例中因为要对应查找三列数据,并且列的位置是对应的,所以用了column函数,如下图所示:
无标题2.jpg
这两点都理解之后,重点就该到index的第二个参数了,这个参数的作用是要查找的内容位于数据区域的第几行,如果是一对一的查找,我们可以指定行号或者用match函数来取得行号,但这里是一对多,例如学号008,分别对应了三个行号,如下图所示:
无标题3.jpg
重要提醒:对这三行数据在表格中的行号我特别标注出来了,分别是4、17和19,但请注意一点,index第一参数所给到的区域并不是从第一行开始的,而是从第二行开始,这一点很重要!
实际上,这三个数据在index给到的范围中,分别位于第3、16和18行,分析到这一步,似乎有点眉目了,我们希望的结果或许应该是这样的:对于学号008,第一次出现时应该是index(数据范围,3,列位置);第二次出现时应该是index(数据范围,16,列位置);第三次出现时应该是index(数据范围,18,列位置);如果还有第四次出现的话,也至是第二参数(行位置)在变化。
以上这段话请务必理解,因为这就是一对多的核心思路,为了将这一想法变成结果,就出来了small+if+row,而这三个函数的组合实际上才是真正的万金油!
SMALL函数:本来这个函数的作用是在给出的一组数据中挑出指定的第几个最小值,第一个参数是一组数字,第二个参数是一个数字……(感觉晕乎乎)
无标题4.jpg
如上图,small 的第一个参数是一组数字,第二个参数是1个数字,这是代表a列这组数据中最小的一个,结果是1;
如果把第二参数改成2,意思就是这组中中第二小的数据,结果是2;
无标题5.jpg
第二参数改成3,结果还是2(因为有好几个2)……
无标题6.jpg
注意,这里的第二参数我们是手动输入的,因为把第一个公式下拉的话,第二参数1是不会变的,如果需要第二参数会自己变,就需要借助ROW函数!(row出现)
可以看看效果:
无标题7.jpg
现在回到我们的问题,还是看看图:
无标题8.jpg
我们需要的是4、17、19(实际上是3、16、18,如果不明白的话从头看,前面重点说过的),要通过small得到这几个数字,有个思路就是:学号=008的,按对应的行号标注,学号≠008的,都看作比28大的数(这个数其实是行号,因为一共27个数),而要实现这个目的,只能通过if实现,IF($A$2:$A$28=$H$2,ROW($1:$27),99),现在来看这一段是不是有点明白了,$A$2:$A$28=$H$2这句的意思就是学号是否等于我们给到的学号,如果是,得到ROW($1:$27),否则都等于99(现在应该明白这个99的作用了吧,本例中99可以改成28的哦),当然如果数据比较多,99就不行了,所以很多时候会用65536(这个数字是旧版的Excel的最大行号),对于使用新版(2007以上)Excel来说,这个数字就变成1048576,看上去很长,也不好记,高手们就想了个办法,用2^10来代替这个数(2^10是2的10次方),更简单的还有用8^8,9^9来写的,作用都一样,就是一个够大的数,呵呵,好像有点跑题了……
我们来看看IF($A$2:$A$28=$H$2,ROW($1:$27),99)这一段的运算结果吧:
无标题9.jpg
注意到3、16、18了吗?
这段if是否已经明白?
如果明白的话,small的第一个参数(一组数)我们就得到了,那么:SMALL(IF($A$2:$A$28=$H$2,ROW($1:$27),99),ROW(A1))这段small是否可以明白呢?
不明白的话往上翻,看看中间部分解释small的……
如果明白的话,3、16、18都得到了,引用前面思路分析的一段话:我们希望的结果或许应该是这样的:对于学号008,第一次出现时应该是index(数据范围,3,列位置);第二次出现时应该是index(数据范围,16,列位置);第三次出现时应该是index(数据范围,18,列位置);
将这个small放入index就得到了INDEX($B$2:$D$28,SMALL(IF($A$2:$A$28=$H$2,ROW($1:$27),99),ROW(A1)),COLUMN(A1))……
记得公式是数组的,写完或者修改后都需要按住Ctrl和shift再回车的!
至于最外层的iferror,只是为了显示效果干净一点。
末尾要说的一点话关于:这个万金油公式,网上或许会有很多的解释,但是没有像我写的这么啰嗦的,不知道各位看的是否明白?其实这个公式真的很难,涉及到很多的知识点,最起码的数组公式的理解,逻辑值的应用,甚至很简单的row函数,column函数,if函数等等,要想用精都不是一朝一夕的事情。但是也只有真的理解了这类经典的函数组合,熟练的掌握了函数嵌套后,你的Excel才能算是入门了吧!

评分

23

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-2-20 01:37 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-2-20 10:59 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-2-20 17:01 | 显示全部楼层
small很关键。。依次取最小数,获得对应的行号啥的。。。这公式太实用了。。哈哈

TA的精华主题

TA的得分主题

发表于 2018-2-20 18:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
我用不起,不知道什么原因.谁有具体的步骤吗?

TA的精华主题

TA的得分主题

发表于 2018-2-20 18:29 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-2-20 18:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
用起了.要用数组公式

TA的精华主题

TA的得分主题

发表于 2018-3-7 10:02 | 显示全部楼层
正好时后续需要使用,不过目前还是看天书的感觉,后续慢慢琢磨琢磨,感谢分享。

TA的精华主题

TA的得分主题

发表于 2018-5-2 19:30 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-7-11 17:29 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-26 17:35 , Processed in 0.048375 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表