Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 30013|回复: 75

[分享] VLOOKUP函数使用四部曲(高级完结篇)

  [复制链接]
发表于 2011-11-22 12:29 | 显示全部楼层 |阅读模式
前言:前面我们分别学习了VLOOKUP函数的入门、初级和进阶篇。今天我们学习VLOOKUP函数的高级应用部分-VLOOKUP函数的数组应用。(本文由兰色幻想原创,转载请注明转自excel精英培训
一、VLOOKUP的反向查找。
    一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。
    例1:要求在如下图所示表中的姓名反查工号。
       VLOOKUP1.jpg
     公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)
    公式剖析:
        1、这里其实不是VLOOKUP可以实现从右至右的查找,而是利用IF函数的数组效应把两列换位重新组合后,再按正常的从左至右查找。
        2、IF({1,0},B2:B5,A2:A5)这是本公式中最重要的组成部分。在EXCEL函数中使用数组时(前提时该函数的参数支持数组),返回的结果也会是一个数组。这里1和0不是实际意义上的数字,而是1相关于TRUE,0相当于FALSE,当为1时,它会返回IF的第二个参数(B列),为0时返回第二个参数(A列)。根据数组运算返回数组,所以使用IF后的结果返回一个数组(非单元格区域):{"张一","A001";"赵三","A002";"杨五","A003";"孙二","A004"}
二、VLOOKUP函数的多条件查找。
      VLOOKUP函数需要借用数组才能实现多条件查找。
     例2:要求根据部门和姓名查找C列的加班时间。
vlookup2.jpg    
分析:我们可以延用例1的思路,我们的努力方向不是让VLOOKUP本身实现多条件查找,而是想办法重构一个数组。多个条件我们可以用&连接在一起,同样两列我们也可以连接成一列数据,然后用IF函数进行组合。
    公式:{=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}
    公式剖析
       1、A9&B9 把两个条件连接在一起。把他们做为一个整体进行查找。
       2、A2:A5&B2:B5,和条件连接相对应,把部分和姓名列也连接在一起,作为一个待查找的整体。
       3、IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把连接后的两列与C列数据合并成一个两列的内存数组。按F9后可以查看的结果为:
       {"销售张一",1;"销售赵三",5;"人事杨五",3;"销售赵三",6}
       4、完成了数组的重构后,接下来就是VLOOKUP的基本查找功能了,另外公式中含有多个数据与多个数据运算(A2:A5&B2:B5),,所以必须以数组形式输入,即按ctrl+shift后按ENTER结束输入。
     三、VLOOKUP函数的批量查找。
     VLOOKUP一般情况下只能查找一个,那么多项该怎么查找呢?
     例3 要求把如图表中所有张一的消费金额全列出来
VLOOKUP3.jpg
分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的查找时,努力的方向是怎么重构一个查找内容和查找的区域。要想实现多项查找,我们可以对查找的内容进行编号,第一个出现的是后面连接1,第二个出现的连接2。。。
     公式:{=VLOOKUP(B$9&ROW(A1),IF({1,0},$B$2:$B$6&COUNTIF(INDIRECT("b2:b"&ROW($2:$6)),B$9),$C$2:$C$6),2,)}
     公式剖析:
        1、B$9&ROW(A1) 连接序号,公式向下复制时会变成B$9连接1,2,3
        2、给所有的张一进行编号。要想生成编号,就需要生成一个不断扩充的区域(INDIRECT("b2:b"&ROW($2:$6)),然后在这个逐行扩充的区域内统计“张一”的个数,在连接上$B$2:$B$6后就可以对所有的张一进行编号了。
       3、IF({1,0}把编号后的B列和C组重构成一个两列数组
     通过以上的讲解,我们需要知道:VLOOKUP函数的基本用法是固定的,要实现高级查找,就需要借助其他函数来重构查找内容和查找数组
     至此VLOOKUP函数从入门到高级的四篇VLOOKUP函数使用教程全部结束了,VLOOKUP函数在数组运算中还有着其他应用,但只是配角了,所以本系列不再介绍。由于笔者水平有限,不免有错漏之处,请大家多多指点。
                  -------兰色幻想于2011年11月22日、
附:      VLOOKUP函数的使用方法(入门级)
        VLOOKUP函数的使用方法(初级篇)
        VLOOKUP函数的使用方法(进阶篇)
示例下载: VLOOKUP函数高级应用.rar (8.98 KB, 下载次数: 867)
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2011-11-22 12:33 | 显示全部楼层
回复

使用道具 举报

发表于 2011-11-22 12:33 | 显示全部楼层
回复

使用道具 举报

发表于 2011-11-22 12:38 | 显示全部楼层
回复

使用道具 举报

发表于 2011-11-22 12:51 | 显示全部楼层
学习学习            
回复

使用道具 举报

发表于 2011-11-22 12:57 | 显示全部楼层
回复

使用道具 举报

发表于 2011-11-22 13:03 | 显示全部楼层
学习学习
回复

使用道具 举报

发表于 2011-11-22 13:49 | 显示全部楼层
酸酸地来一句:介个……好眼熟啊……
回复

使用道具 举报

发表于 2011-11-22 14:16 | 显示全部楼层
学习
回复

使用道具 举报

发表于 2011-11-22 14:16 | 显示全部楼层
学习学习
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-20 15:08 , Processed in 0.449048 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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