Excel使用函数在A列提取最后一个星号后的数字并在B列显示
1680
2022-07-28
今天和大家分享的主题是Excel函数常用的各种条件查询套路总结,内容涵盖了单条件数据查询、多条件数据查询、精确查询、模糊条件查询、多结果数据查询以及动态表格查询、多表数据查询等。建议收藏哦~
1,单条件单结果查询
酱紫的问题,我们最常用VLOOKUP函数。
VLOOKUP函数的语法非常简单。
=VLOOKUP(找谁,在哪里找,查找值在查找范围中的第几列?0失误找还是随便找?)
但该函数有3个新手容易犯错的注意点:
1, 查找值必须在查找范围的首列。
2, 第3参数是返回查找值在查找范围中的第几列,而不是表格的第几列。
3, 第4个参数是匹配方式,当使用精确匹配方式时,通常输入0。
当查找值不在查找范围首列时,与其选择VLOOKUP函数,不如使用INDEX+MATCH函数组合。
公式:
=INDEX(A:A,MATCH(D2,B:B,0))
MATCH函数先取得D2单元格的值在B列中的序列号,然后通过INDEX函数按图索骥取得结果。
有一部分表亲此时依然喜欢使用VLOOKUP函数:
{=VLOOKUP(D2,IF({1,0},B:B,A:A),2,0)}
坦白说,该数组公式计算效率和编写体验都奇差无比,是2B青年糊弄小白新手的常用伎俩,少用为宜。
2,多条件单结果查询
这样的问题我们通常使用LOOKUP函数。该套路可以总结为:
=LOOKUP(1,0/(条件1*条件2……),结果区域)
如下图所示,C10单元格公式:
=LOOKUP(1,0/((A$2:A$7=E2)*(B$2:B$7=F2)),C$2:C$7)
3,单条件模糊查询
Excel内常用的通配符有两个。一个星号(*),一个问号(?)。
星号可以代替任意个字符,既可以是0个,也可以是多个。
问号只能代替任意一个字符。
MATCH函数和VLOOKUP函数都支持通配符的使用。
如下图所示,两个函数都可以解决问题。
公式1:=VLOOKUP("*"&D2&"*",A:B,2,0)
公式2:=INDEX(B:B,MATCH("*"&D2&"*",A:A,0))
4,多条件模糊查询
多条件模糊查询依然可以使用LOOKUP(1,0/(条件),结果)的经典套路。
下面的公式利用SEARCH函数支持使用通配符的特性(FIND函数不支持通配符),进行模糊查询匹配。
公式:
=LOOKUP(1,0/SEARCH("*"&A10&"*"&B10&"*",A$2:A$7&B$2:B$7),C$2:C$7)
5,多结果数据查询:
该问题依然有一个经典的万金油函数查询套路,INDEX+SMALL+IF。
公式:
=INDEX($B:$B,SMALL(IF($A$1:$A$7=$D$2,ROW($1:$7)),ROW(A1)))
解说:
公式先通过IF函数判断A1:A7的数据是否等于D2单元格的查询值,如果相等,则返回对应值的行号,否则返回逻辑值FALSE;然后通过SMALL函数对行号从小到大取值,最后通过INDEX函数根据行号按图索骥取得最后的查询结果。
6,动态表格数据查询
当根据单元格所输入或选择的表名,动态性的对相应的表格进行数据查询时,我们通常嵌套INDIRECT函数构建动态查询区域。
如下图所示,根据B1单元格输入的表名,查询B2单元格在该表所对应的成绩结果。
公式:
=VLOOKUP(B2,INDIRECT(B1&"!A:B"),2,0)
7,多表格数据查询
一个工作簿有多个表格,当你并不知道该查询值可能存在哪个表格时,可以使用以下多表数据查询套路。
假设表格名称是1~12月。
公式:
=VLOOKUP(B1,INDIRECT(LOOKUP(1,0/COUNTIF(INDIRECT(ROW($1:$12)&"月!A:A"),B1),ROW($1:$12)&"月!a:b")),2,0)
解说:
该公式先通过INDIRECT(ROW($1:$12)&"月!A:A")构建多表数据区域,通过COUNTIF判断查询值在多表数据区域(A列)是否存在,然后通过LOOKUP的条件查询套路返回相应的表格名称,最后再使用INDIRECT函数对LOOKUP的表名查询结果构建VLOOKUP函数的查询区域,进而取得最后查询结果
发表评论
暂时没有评论,来抢沙发吧~