Vlookup大叔与一对多查找(Excel函数集团)
所谓一对多查找,就是根据一个条件,把多个符合条件的结果全部找出来。
其实吧,一对多查找不是什么,尤其是O365的Filter函数横空出世震撼全场之后,简直就是瞬间把所有传统的数组解法甩出去七八十来条街……
但是!
这世上有一种人,叫“没了Vlookup就吃不好睡不香”,但凡和查找搭上半点关系的问题,都必须肯定一定确定要用早已油腻的Vlookup大叔来解决。
Vlookup大叔表示,心累!
比如表格结构如下图的一个一对多查找问题:
好在V大叔有个特别之处,就是他的参数常常会弄出些意外,比如第一参数¥#¥%@……
再比如第二参数#¥%&¥#……
所以就生出了这么个野路子的公式:
=VLOOKUP(D$2,INDIRECT("a"&SMALL(IF(A$2:A$17=D$2,ROW($2:$17)),ROW(A1))&":b17"),2,)
好吧,这公式就这么一亮相,肯定是支持头晕模式的,还是一步一步来拆解吧。
首先,当我们遇到这个问题时,如果只需要找第一个“乙”所对应的“B”,V大叔的标准写法是:
=VLOOKUP(D$2,A2:B17,2,)
其中的A2:B17是查找范围,直接引用。如果改用间接引用,并不影响公式结果:
=VLOOKUP(D$2,INDIRECT("A2:B17"),2,)
即然用了间接引用,A2:B17就不再是单元格地址,而是变成了字符串,可以各种拆解了,比如拆解成这样:
=VLOOKUP(D$2,INDIRECT("A"&2&":B17"),2,)
这样一来,其中的2就被单独拎了出来,这其中就可以加上一个一对多查找的惯用手法:
=VLOOKUP(D$2,INDIRECT("A"&SMALL(IF(A$2:A$17=D$2,ROW($2:$17)),ROW(A1))&":B17"),2,)
文字解释一下就是如果A2:A17这些等于D2,也就是符合条件时,返回对应的行号,再用Small函数对返回的结果通过公式向下复制的方式从小到大排列。
所以这公式,就是这么回事了。
那么,为什么V大叔这么用就可以起到一对多查找的效果呢?如果把"A"&SMALL(IF(A$2:A$17=D$2,ROW($2:$17)),ROW(A1))&":B17"部分单独放在一个单元格里,前面加上等号,公式完成后再向下复制,就会得出A3:B17、A7:B17、A11:B17和A15:B17这样的结果。
说得再透明点就是,第一个公式是让V大叔在A3:B17这个范围内找D2对应的结果;向下复制到第二个公式是让V大叔在A7:B17这个范围内找D2对应的结果;继续向下复制到第三个公式是让V大叔在A11:B17这个范围内找D2对应的结果;第四个公式是让V大叔在A15:B17这个范围内找D2对应的结果。
所以这结果是正确的、愉快的、大得V大叔忠粉们心的、皆大欢喜的……
可偏偏这公式,是个野路子,因为,选取第二参数后按F9功能键,结果是奇特奇异奇怪的。
当然这结果也并非来自地球以外,之所以会这样,是因为Indirect的结果,是多维引用,而正经路子多维引用都是在外面套用SumIf、Subtotal、DSum这些函数, 且完成以后的公式还可以再在外面套函数,详参多工作表汇总的相关公式。
而V大叔用在这时,就只能这样了,想要在外面再套别的函数,那就……没结果了。
这是不是函数中的一个Bug呢?
但是,不管是真Bug还是假Bug,不管是正路子还是野路子,只要能解决问题,同时大得V大叔忠粉们的心,就是好路子!
最后提示一小下下,如果您的电脑不支持动态数组,公式结束后请按【Ctrl+Shift+Enter】组合键,以免乐极生悲。
Vlookup大叔与一对多查找(Excel函数集团)的更多相关文章
- 个人永久性免费-Excel催化剂功能第38波-比Vlookup更好用的查找引用函数
谈起Excel的函数,有一个函数生来自带明星光环,在表哥表姐群体中无人不知,介绍它的教程更是铺天盖地,此乃VLOOKUP函数也.今天Excel催化剂在这里冒着被火喷的风险,大胆地宣布一个比VLOOKU ...
- Vlookup大叔早已油腻(Excel函数集团)
1.Vlookup基础用法:https://mp.weixin.qq.com/s/0JRytWlBD-KYM2jkecG2rA 2.合并字符串:https://mp.weixin.qq.com/s/9 ...
- 查找与引用函数(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业!谢谢 下载地址:https://officecommunity-m ...
- 替DateDif哭诉一把(Excel函数集团)
Excel中有个工作表函数DateDif,专门用来计算两日期之间的日差.月差.年差,传说十分好用. 具体用法在此就省略了,好奇的童鞋请自行*度~ 可是,在Excel里,他却是个"没户口&qu ...
- LET函数(Excel函数集团)
LET函数,是个Office365新增函数,所以,还在用上古版本的童鞋请无视此篇哈~ 话说Excel中,有个自定义名称的功能,如下图,左右两个表分别自定义了"data1"和&quo ...
- 字符串函数(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业!谢谢 下载地址:https://officecommunity-m ...
- 日期与时间函数(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业!谢谢 下载地址:https://officecommunity-m ...
- 统计函数(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业! 谢谢 下载地址:https://officecommunity- ...
- 数组基础(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业! 谢谢 下载地址:https://officecommunity- ...
随机推荐
- [spojSUBST1]New Distinct Substrings
求出后缀数组和height数组,然后因为子串即后缀的前缀,考虑不断新增后缀然后计算贡献,如果以sa的顺序新增那么第i个就会产生n-sa[k]+1-h[k](n-sa[k]+1为总方案,h为不合法的方案 ...
- [atAGC020E]Encoding Subsets
令$f_{S}$表示字符串$S$的答案(所有子集的方案数之和),考虑转移: 1.最后是一个字符串,不妨仅考虑最后一个字符,即$f_{S[1,|S|)}$(字符串下标从1开始),特别的,若$S_{|S| ...
- 【机器学习基础】卷积神经网络(CNN)基础
最近几天陆续补充了一些"线性回归"部分内容,这节继续机器学习基础部分,这节主要对CNN的基础进行整理,仅限于基础原理的了解,更复杂的内容和实践放在以后再进行总结. 卷积神经网络的基 ...
- 详解Threejs中的光源对象
光源的分类 AmbientLight(环境光),PointLight(点光源),SpotLight(聚光源) 和 DirectionalLight(平行光)是基础光源 HemisphereLight( ...
- Atcoder Grand Contest 038 E - Gachapon(Min-Max 容斥+背包)
Atcoder 题面传送门 & 洛谷题面传送门 我竟然能独立做出 Ag 的 AGC E,incredible!更新了 Atcoder 做题难度上限( 首先按照套路 Min-Max 容斥,\(a ...
- snpEff注释结果各区域统计之和大于变异总数?
目录 问题一:各区域注释之和大于变异总数? 问题二:注释Region出现Gene和transcript等区域? 问题一:各区域注释之和大于变异总数? snpEff的结果很简单,但常常遇到如下问题. 我 ...
- R语言与医学统计图形-【28】ggplot2扩展包ggrepel、ggsci、gganimate、ggpubr
ggplot2绘图系统--扩展包ggrepel.ggsci.gganimate.ggpubr等 部分扩展包可在CRAN直接下载,有些需借助devtools包从Github下载. 1. ggrepel包 ...
- char和varchar2
1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的. 比如,存储字符串"abc",对于CHAR (10),表示你存储的字符将占10个字节(包括7个空字符) 而同样的V ...
- cpu的性能测试
#!/bin/bash #user%加上sys%是性能的评判标准 User_sys_a=`sar -u 1 3 |tail -1 |awk '{print $3"+"$5}'|bc ...
- mongodb存储的基本使用
Python连接mongodb一般使用pymongo模块 1. pymongo模块的简单使用 ### MongoDB存储 ## 连接MongoDB import pymongo # 建立连接对象,2种 ...