文档介绍:蝿 一、VLOOKUP的反向查找。芄   一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。蒃    例1:要求在如下图所示表中的姓名反查工号。袃     薈薈    公式:=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列的加班时间。莀螈    分析:我们可以延用例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要求把如图表中所有张一的消费金额全列出来袀羈     分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的