精华内容
下载资源
问答
  • VLOOKUP函数是EXCEL最常用的查找函数,本文将常见VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间...

    VLOOKUP函数是EXCEL最常用的查找函数,本文将常见的VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。

    01

    VLOOKUP函数怎么用?

    VLOOKUP是一个查找函数,给定一个查找的目标,它就能从指定的查找区域中查找返回想要查找到的值。

    它的基本语法为:

    VLOOKUP(查找目标,查找范围,返回值的列数,精确OR模糊查找)

    下面以一个实例来介绍一下这四个参数的使用。

    例:如下图所示,要求根据表二中的姓名,查找姓名所对应的年龄。

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    参数说明:

    查找目标:就是你指定的查找的内容或单元格引用。本例中表二A列的姓名就是查找目标。我们要根据表二的“姓名”在表一中A列进行查找。

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    查找范围(VLOOKUP(A13,$B$2:$D$8,3,0) ):指定了查找目标,如果没有说从哪里查找,EXCEL肯定会很为难。所以下一步我们就要指定从哪个范围中进行查找。VLOOKUP的这第二个参数可以从一个单元格区域中查找,也可以从一个常量数组或内存数组中查找。

    本例中要从表一中进行查找,那么范围我们要怎么指定呢?这里也是极易出错的地方。大家一定要注意,给定的第二个参数查找范围要符合以下条件才不会出错:

    • 查找目标一定要在该区域的第一列。本例中查找表二的姓名,那么姓名所对应的表一的姓名列,那么表一的姓名列(列)一定要是查找区域的第一列。像本例中,给定的区域要从第二列开始,即$B$2:$D$8,而不能是$A$2:$D$8。因为查找的“姓名”不在$A$2:$D$8区域的第一列。

    • 该区域中一定要包含要返回值所在的列,本例中要返回的值是年龄。年龄列(表一的D列)一定要包括在这个范围内,即:$B$2:$D$8,如果写成$B$2:$C$8就是错的。

    返回值的列数(B13 =VLOOKUP(A13,$B$2:$D$8,3,0))。这是VLOOKUP第3个参数。它是一个整数值。它怎么得来的呢。它是“返回值”在第二个参数给定的区域中的列数。本例中我们要返回的是“年龄”,它是第二个参数查找范围$B$2:$D$8的第3列。

    这里一定要注意,列数不是在工作表中的列数(不是第4列),而是在查找范围区域的第几列。如果本例中要是查找姓名所对应的性别,第3个参数的值应该设置为多少呢。答案是2。因为性别在$B$2:$D$8的第2列中。

    精确OR模糊查找(VLOOKUP(A13,$B$2:$D$8,3,0) ),最后一个参数是决定函数精确和模糊查找的关键。精确即完全一样,模糊即包含的意思。第4个参数如果指定值是0或FALSE就表示精确查找,而值为1或TRUE时则表示模糊。

    这里小编提醒大家切记切记,在使用VLOOKUP时千万不要把这个参数给漏掉了,如果缺少这个参数默为值为模糊查找,我们就无法精确查找到结果了。

    02

    VLOOKUP的反向查找

    VLOOKUP的反向查找,需要用IF函数把数据源倒置一下。一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。

    例:要求在如下图所示表中的姓名反查工号。

    公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)

    公式剖析:

    • 这里其实不是VLOOKUP可以实现从右至左的查找,而是利用IF函数的数组效应把两列换位重新组合后,再按正常的从左至右查找。

    • IF({1,0},B2:B5,A2:A5)这是本公式中最重要的组成部分。在EXCEL函数中使用数组时(前提是该函数的参数支持数组),返回的结果也会是一个数组。这里1和0不是实际意义上的数字,而是1相关于TRUE,0相当于FALSE,当为1时,它会返回IF的第二个参数(B列),为0时返回第二个参数(A列)。根据数组运算返回数组,所以使用IF后的结果返回一个数组(非单元格区域):{'张一','A001';'赵三','A002';'杨五','A003';'孙二','A004'}

    03

    VLOOKUP的模糊查找

    模糊查找就是匹配查找。在A列我们知道如何查找型号为“AAA”的产品所对应的B列价格,即:=VLOOKUP(C1,A:B,2,0)

    如果需要查找包含“AAA”的产品名称怎么表示呢?如下图表中所示。

    公式=VLOOKUP('*'&A10&'*',A2:B6,2,0)

    公式说明:VLOOKUP的第一个参数允许使用通配符“*”来表示包含的意思,把*放在字符的两边,即'*' & 字符 & '*'。

    04

    VLOOKUP的区间查找

    数字的区间查找即给定多个区间,指定一个数就可以查找出它在哪个区间并返回这个区间所对应的值。

    VLOOKUP的第4个参数,如果为0或FALSE是精确查找,如果是1或TRUE或省略则为模糊查找,那么实现区间查找正是第4个参数的模糊查找应用。

    首先需要了解一下VLOOKUP函数模糊查找的两个重要规则:

    • 引用的数字区域一定要从小到大排序。杂乱的数字是无法准确查找到的。如下面A列符合模糊查找的前题,B列则不符合。

    • 模糊查找的原理是:给一定个数,它会找到和它最接近,但比它小的那个数。详见下图说明。

    最后看一个实例:

    例:如下图所示,要求根据上面的提成比率表,在提成表计算表中计算每个销售额的提成比率和提成额。

    公式:=VLOOKUP(A11,$A$3:$B$7,2)

    公式说明:

    • 上述公式省略了VLOOKUP最后一个参数,相当于把第四个参数设置成1或TRUE。这表示VLOOKUP要进行数字的区间查找。

    • 图中公式中在查找5000时返回比率表0所对应的比率1%,原因是0和10000与5000最接近,但VLOOKUP只选比查找值小的那一个,所以公式会返回0所对应的比率1%。

    05

    VLOOKUP的多条件查找

    VLOOKUP函数需要借用数组才能实现多条件查找。例:要求根据部门和姓名查找C列的加班时间。

    分析:不是让VLOOKUP本身实现多条件查找,而是想办法重构一个数组。多个条件可以用&连接在一起,同样两列也可以连接成一列数据,然后用IF函数进行组合。

    公式:

    {=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}

    公式剖析:

    • A9&B9 把两个条件连接在一起。把他们做为一个整体进行查找。

    • A2:A5&B2:B5,和条件连接相对应,把部分和姓名列也连接在一起,作为一个待查找的整体。

    • IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把连接后的两列与C列数据合并成一个两列的内存数组。

    按F9后可以查看的结果为:

    {'销售张一',1;'销售赵三',5;'人事杨五',3;'销售赵三',6}

    完成了数组的重构后,接下来就是VLOOKUP的基本查找功能了,另外公式中含有多个数据与多个数据运算(A2:A5&B2:B5),所以必须以数组形式输入,即按ctrl+shift后按ENTER结束输入。

    06

    VLOOKUP的多项查找

    VLOOKUP一般情况下只能查找一个,那么多项该怎么查找呢?例3 要求把如图表中所有张一的消费金额全列出来。

    分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的查找时,努力的方向是怎么重构一个查找内容和查找的区域。要想实现多项查找,我们可以对查找的内容进行编号,第一个出现的是后面连接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,)}

    公式剖析:

    • B$9&ROW(A1) 连接序号,公式向下复制时会变成B$9连接1,2,3

    • 给所有的张一进行编号。要想生成编号,就需要生成一个不断扩充的区域(INDIRECT('b2:b'&ROW($2:$6)),然后在这个逐行扩充的区域内统计“张一”的个数,在连接上$B$2:$B$6后就可以对所有的张一进行编号了

    • IF({1,0}把编号后的B列和C组重构成一个两列数组

    通过以上的讲解,需要知道,VLOOKUP函数的基本用法是固定的,要实现高级查找,就需要借助其他函数来重构查找内容和查找数组。

    End.

    作者:青路

    来源:360个人图书馆

    本文为转载分享,如侵权请联系后台删除

    电影院要开门了,最受期待的电影是...

    12000+字超详细 SQL 语法速成!

    后台回复“入群”即可入群交流数据干货
    
    展开全文
  • VLOOKUP函数是EXCEL最常用的查找函数,本文将常见VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间...

    VLOOKUP函数是EXCEL最常用的查找函数,本文将常见的VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。

    01

    VLOOKUP函数怎么用?

    VLOOKUP是一个查找函数,给定一个查找的目标,它就能从指定的查找区域中查找返回想要查找到的值。

    它的基本语法为:

    VLOOKUP(查找目标,查找范围,返回值的列数,精确OR模糊查找)

    下面以一个实例来介绍一下这四个参数的使用。

    例:如下图所示,要求根据表二中的姓名,查找姓名所对应的年龄。

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    参数说明:

    查找目标:就是你指定的查找的内容或单元格引用。本例中表二A列的姓名就是查找目标。我们要根据表二的“姓名”在表一中A列进行查找。

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    查找范围(VLOOKUP(A13,$B$2:$D$8,3,0) ):指定了查找目标,如果没有说从哪里查找,EXCEL肯定会很为难。所以下一步我们就要指定从哪个范围中进行查找。VLOOKUP的这第二个参数可以从一个单元格区域中查找,也可以从一个常量数组或内存数组中查找。

    本例中要从表一中进行查找,那么范围我们要怎么指定呢?这里也是极易出错的地方。大家一定要注意,给定的第二个参数查找范围要符合以下条件才不会出错:

    • 查找目标一定要在该区域的第一列。本例中查找表二的姓名,那么姓名所对应的表一的姓名列,那么表一的姓名列(列)一定要是查找区域的第一列。像本例中,给定的区域要从第二列开始,即$B$2:$D$8,而不能是$A$2:$D$8。因为查找的“姓名”不在$A$2:$D$8区域的第一列。

    • 该区域中一定要包含要返回值所在的列,本例中要返回的值是年龄。年龄列(表一的D列)一定要包括在这个范围内,即:$B$2:$D$8,如果写成$B$2:$C$8就是错的。

    返回值的列数(B13 =VLOOKUP(A13,$B$2:$D$8,3,0))。这是VLOOKUP第3个参数。它是一个整数值。它怎么得来的呢。它是“返回值”在第二个参数给定的区域中的列数。本例中我们要返回的是“年龄”,它是第二个参数查找范围$B$2:$D$8的第3列。

    这里一定要注意,列数不是在工作表中的列数(不是第4列),而是在查找范围区域的第几列。如果本例中要是查找姓名所对应的性别,第3个参数的值应该设置为多少呢。答案是2。因为性别在$B$2:$D$8的第2列中。

    精确OR模糊查找(VLOOKUP(A13,$B$2:$D$8,3,0) ),最后一个参数是决定函数精确和模糊查找的关键。精确即完全一样,模糊即包含的意思。第4个参数如果指定值是0或FALSE就表示精确查找,而值为1或TRUE时则表示模糊。

    这里小编提醒大家切记切记,在使用VLOOKUP时千万不要把这个参数给漏掉了,如果缺少这个参数默为值为模糊查找,我们就无法精确查找到结果了。

    02

    VLOOKUP的反向查找

    VLOOKUP的反向查找,需要用IF函数把数据源倒置一下。一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。

    例:要求在如下图所示表中的姓名反查工号。

    公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)

    公式剖析:

    • 这里其实不是VLOOKUP可以实现从右至左的查找,而是利用IF函数的数组效应把两列换位重新组合后,再按正常的从左至右查找。

    • IF({1,0},B2:B5,A2:A5)这是本公式中最重要的组成部分。在EXCEL函数中使用数组时(前提是该函数的参数支持数组),返回的结果也会是一个数组。这里1和0不是实际意义上的数字,而是1相关于TRUE,0相当于FALSE,当为1时,它会返回IF的第二个参数(B列),为0时返回第二个参数(A列)。根据数组运算返回数组,所以使用IF后的结果返回一个数组(非单元格区域):{'张一','A001';'赵三','A002';'杨五','A003';'孙二','A004'}

    03

    VLOOKUP的模糊查找

    模糊查找就是匹配查找。在A列我们知道如何查找型号为“AAA”的产品所对应的B列价格,即:=VLOOKUP(C1,A:B,2,0)

    如果需要查找包含“AAA”的产品名称怎么表示呢?如下图表中所示。

    公式=VLOOKUP('*'&A10&'*',A2:B6,2,0)

    公式说明:VLOOKUP的第一个参数允许使用通配符“*”来表示包含的意思,把*放在字符的两边,即'*' & 字符 & '*'。

    04

    VLOOKUP的区间查找

    数字的区间查找即给定多个区间,指定一个数就可以查找出它在哪个区间并返回这个区间所对应的值。

    VLOOKUP的第4个参数,如果为0或FALSE是精确查找,如果是1或TRUE或省略则为模糊查找,那么实现区间查找正是第4个参数的模糊查找应用。

    首先需要了解一下VLOOKUP函数模糊查找的两个重要规则:

    • 引用的数字区域一定要从小到大排序。杂乱的数字是无法准确查找到的。如下面A列符合模糊查找的前题,B列则不符合。

    • 模糊查找的原理是:给一定个数,它会找到和它最接近,但比它小的那个数。详见下图说明。

    最后看一个实例:

    例:如下图所示,要求根据上面的提成比率表,在提成表计算表中计算每个销售额的提成比率和提成额。

    公式:=VLOOKUP(A11,$A$3:$B$7,2)

    公式说明:

    • 上述公式省略了VLOOKUP最后一个参数,相当于把第四个参数设置成1或TRUE。这表示VLOOKUP要进行数字的区间查找。

    • 图中公式中在查找5000时返回比率表0所对应的比率1%,原因是0和10000与5000最接近,但VLOOKUP只选比查找值小的那一个,所以公式会返回0所对应的比率1%。

    05

    VLOOKUP的多条件查找

    VLOOKUP函数需要借用数组才能实现多条件查找。例:要求根据部门和姓名查找C列的加班时间。

    分析:不是让VLOOKUP本身实现多条件查找,而是想办法重构一个数组。多个条件可以用&连接在一起,同样两列也可以连接成一列数据,然后用IF函数进行组合。

    公式:

    {=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}

    公式剖析:

    • A9&B9 把两个条件连接在一起。把他们做为一个整体进行查找。

    • A2:A5&B2:B5,和条件连接相对应,把部分和姓名列也连接在一起,作为一个待查找的整体。

    • IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把连接后的两列与C列数据合并成一个两列的内存数组。

    按F9后可以查看的结果为:

    {'销售张一',1;'销售赵三',5;'人事杨五',3;'销售赵三',6}

    完成了数组的重构后,接下来就是VLOOKUP的基本查找功能了,另外公式中含有多个数据与多个数据运算(A2:A5&B2:B5),所以必须以数组形式输入,即按ctrl+shift后按ENTER结束输入。

    06

    VLOOKUP的多项查找

    VLOOKUP一般情况下只能查找一个,那么多项该怎么查找呢?例3 要求把如图表中所有张一的消费金额全列出来。

    分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的查找时,努力的方向是怎么重构一个查找内容和查找的区域。要想实现多项查找,我们可以对查找的内容进行编号,第一个出现的是后面连接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,)}

    公式剖析:

    • B$9&ROW(A1) 连接序号,公式向下复制时会变成B$9连接1,2,3

    • 给所有的张一进行编号。要想生成编号,就需要生成一个不断扩充的区域(INDIRECT('b2:b'&ROW($2:$6)),然后在这个逐行扩充的区域内统计“张一”的个数,在连接上$B$2:$B$6后就可以对所有的张一进行编号了

    • IF({1,0}把编号后的B列和C组重构成一个两列数组

    通过以上的讲解,需要知道,VLOOKUP函数的基本用法是固定的,要实现高级查找,就需要借助其他函数来重构查找内容和查找数组。

    End.

    作者:青路

    来源:360个人图书馆

    本文为转载分享,如侵权请联系后台删除

    我的这份Pandas实战PDF,你收藏了吗?

    12000+字超详细 SQL 语法速成!

    后台回复“入群”即可入群交流数据干货
    

    干货????

    展开全文
  • VLOOKUP函数是EXCEL最常用的查找函数,本文将常见VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。01VLOOKUP函数怎么用...

    16fcc23e8af373c53abba183982e6a8c.png

    VLOOKUP函数是EXCEL最常用的查找函数,本文将常见的VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。

    01

    VLOOKUP函数怎么用?

    VLOOKUP是一个查找函数,给定一个查找的目标,它就能从指定的查找区域中查找返回想要查找到的值。

    它的基本语法为:

    VLOOKUP(查找目标,查找范围,返回值的列数,精确OR模糊查找)

    下面以一个实例来介绍一下这四个参数的使用。

    例:如下图所示,要求根据表二中的姓名,查找姓名所对应的年龄。

    aa6df7e7d6425aadc1e6d63607b11972.png

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    参数说明:

    查找目标:就是你指定的查找的内容或单元格引用。本例中表二A列的姓名就是查找目标。我们要根据表二的“姓名”在表一中A列进行查找。

    公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

    查找范围(VLOOKUP(A13,$B$2:$D$8,3,0) ):指定了查找目标,如果没有说从哪里查找,EXCEL肯定会很为难。所以下一步我们就要指定从哪个范围中进行查找。VLOOKUP的这第二个参数可以从一个单元格区域中查找,也可以从一个常量数组或内存数组中查找。

    本例中要从表一中进行查找,那么范围我们要怎么指定呢?这里也是极易出错的地方。大家一定要注意,给定的第二个参数查找范围要符合以下条件才不会出错:

    • 查找目标一定要在该区域的第一列。本例中查找表二的姓名,那么姓名所对应的表一的姓名列,那么表一的姓名列(列)一定要是查找区域的第一列。像本例中,给定的区域要从第二列开始,即$B$2:$D$8,而不能是$A$2:$D$8。因为查找的“姓名”不在$A$2:$D$8区域的第一列。
    • 该区域中一定要包含要返回值所在的列,本例中要返回的值是年龄。年龄列(表一的D列)一定要包括在这个范围内,即:$B$2:$D$8,如果写成$B$2:$C$8就是错的。

    返回值的列数(B13 =VLOOKUP(A13,$B$2:$D$8,3,0))。这是VLOOKUP第3个参数。它是一个整数值。它怎么得来的呢。它是“返回值”在第二个参数给定的区域中的列数。本例中我们要返回的是“年龄”,它是第二个参数查找范围$B$2:$D$8的第3列。

    这里一定要注意,列数不是在工作表中的列数(不是第4列),而是在查找范围区域的第几列。如果本例中要是查找姓名所对应的性别,第3个参数的值应该设置为多少呢。答案是2。因为性别在$B$2:$D$8的第2列中。

    精确OR模糊查找(VLOOKUP(A13,$B$2:$D$8,3,0) ),最后一个参数是决定函数精确和模糊查找的关键。精确即完全一样,模糊即包含的意思。第4个参数如果指定值是0或FALSE就表示精确查找,而值为1或TRUE时则表示模糊。

    这里小编提醒大家切记切记,在使用VLOOKUP时千万不要把这个参数给漏掉了,如果缺少这个参数默为值为模糊查找,我们就无法精确查找到结果了。

    02

    VLOOKUP的反向查找

    VLOOKUP的反向查找,需要用IF函数把数据源倒置一下。一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。

    例:要求在如下图所示表中的姓名反查工号。

    8188b1cc33d9cab9fecb21b9eb7de8e0.png

    公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)

    公式剖析:

    • 这里其实不是VLOOKUP可以实现从右至左的查找,而是利用IF函数的数组效应把两列换位重新组合后,再按正常的从左至右查找。
    • IF({1,0},B2:B5,A2:A5)这是本公式中最重要的组成部分。在EXCEL函数中使用数组时(前提是该函数的参数支持数组),返回的结果也会是一个数组。这里1和0不是实际意义上的数字,而是1相关于TRUE,0相当于FALSE,当为1时,它会返回IF的第二个参数(B列),为0时返回第二个参数(A列)。根据数组运算返回数组,所以使用IF后的结果返回一个数组(非单元格区域):{'张一','A001';'赵三','A002';'杨五','A003';'孙二','A004'}

    03

    VLOOKUP的模糊查找

    模糊查找就是匹配查找。在A列我们知道如何查找型号为“AAA”的产品所对应的B列价格,即:=VLOOKUP(C1,A:B,2,0)

    如果需要查找包含“AAA”的产品名称怎么表示呢?如下图表中所示。

    ac2382e2d9b1e9a47afafafb2b1568f5.png

    公式=VLOOKUP('*'&A10&'*',A2:B6,2,0)

    公式说明:VLOOKUP的第一个参数允许使用通配符“*”来表示包含的意思,把*放在字符的两边,即'*' & 字符 & '*'。

    04

    VLOOKUP的区间查找

    数字的区间查找即给定多个区间,指定一个数就可以查找出它在哪个区间并返回这个区间所对应的值。

    VLOOKUP的第4个参数,如果为0或FALSE是精确查找,如果是1或TRUE或省略则为模糊查找,那么实现区间查找正是第4个参数的模糊查找应用。

    首先需要了解一下VLOOKUP函数模糊查找的两个重要规则:

    • 引用的数字区域一定要从小到大排序。杂乱的数字是无法准确查找到的。如下面A列符合模糊查找的前题,B列则不符合。
    • 模糊查找的原理是:给一定个数,它会找到和它最接近,但比它小的那个数。详见下图说明。

    最后看一个实例:

    例:如下图所示,要求根据上面的提成比率表,在提成表计算表中计算每个销售额的提成比率和提成额。

    c53ddbddcd641bc867e04c420a129a8a.png

    公式:=VLOOKUP(A11,$A$3:$B$7,2)

    公式说明:

    • 上述公式省略了VLOOKUP最后一个参数,相当于把第四个参数设置成1或TRUE。这表示VLOOKUP要进行数字的区间查找。
    • 图中公式中在查找5000时返回比率表0所对应的比率1%,原因是0和10000与5000最接近,但VLOOKUP只选比查找值小的那一个,所以公式会返回0所对应的比率1%。

    05

    VLOOKUP的多条件查找

    VLOOKUP函数需要借用数组才能实现多条件查找。例:要求根据部门和姓名查找C列的加班时间。

    de8e2b866e0c8db20d4612b7c2dbe8e1.png

    分析:不是让VLOOKUP本身实现多条件查找,而是想办法重构一个数组。多个条件可以用&连接在一起,同样两列也可以连接成一列数据,然后用IF函数进行组合。

    公式:

    {=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}

    公式剖析:

    • A9&B9 把两个条件连接在一起。把他们做为一个整体进行查找。
    • A2:A5&B2:B5,和条件连接相对应,把部分和姓名列也连接在一起,作为一个待查找的整体。
    • IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把连接后的两列与C列数据合并成一个两列的内存数组。

    按F9后可以查看的结果为:

    {'销售张一',1;'销售赵三',5;'人事杨五',3;'销售赵三',6}

    完成了数组的重构后,接下来就是VLOOKUP的基本查找功能了,另外公式中含有多个数据与多个数据运算(A2:A5&B2:B5),所以必须以数组形式输入,即按ctrl+shift后按ENTER结束输入。

    06

    VLOOKUP的多项查找

    VLOOKUP一般情况下只能查找一个,那么多项该怎么查找呢?例3 要求把如图表中所有张一的消费金额全列出来。

    7107c58da3a012c863cf85a4284cc1be.png

    分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的查找时,努力的方向是怎么重构一个查找内容和查找的区域。要想实现多项查找,我们可以对查找的内容进行编号,第一个出现的是后面连接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,)}

    公式剖析:

    • B$9&ROW(A1) 连接序号,公式向下复制时会变成B$9连接1,2,3
    • 给所有的张一进行编号。要想生成编号,就需要生成一个不断扩充的区域(INDIRECT('b2:b'&ROW($2:$6)),然后在这个逐行扩充的区域内统计“张一”的个数,在连接上$B$2:$B$6后就可以对所有的张一进行编号了
    • IF({1,0}把编号后的B列和C组重构成一个两列数组

    通过以上的讲解,需要知道,VLOOKUP函数的基本用法是固定的,要实现高级查找,就需要借助其他函数来重构查找内容和查找数组。

    展开全文
  • VLOOKUP函数是EXCEL最常用的查找函数,本文将常见VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。01VLOOKUP函数怎么用...

    85eda2e3af6ff158b2e89d899b53b47e.png

    e139b156cef6b5b9e547f36f15b097a7.png

    b25e2b5a0cad03e0d04cc7c5f82134ea.png

          VLOOKUP函数是EXCEL最常用的查找函数,本文将常见的VLOOKUP函数相关问题总结一下,主要为VLOOKUP函数怎么用?如何使用VLOOKUP函数进行反向逆向查找、模糊查找、区间查找、多条件查找、多项查找。

    01

    VLOOKUP函数怎么用?

          VLOOKUP是一个查找函数,给定一个查找的目标,它就能从指定的查找区域中查找返回想要查找到的值。

          它的基本语法为:

          VLOOKUP(查找目标,查找范围,返回值的列数,精确OR模糊查找)

          下面以一个实例来介绍一下这四个参数的使用。

          例:如下图所示,要求根据表二中的姓名,查找姓名所对应的年龄。

    4bf5d76a30d32b9eefcddbb02efa876c.png

          公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

          参数说明:

          查找目标:就是你指定的查找的内容或单元格引用。本例中表二A列的姓名就是查找目标。我们要根据表二的“姓名”在表一中A列进行查找。

          

          公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)

          查找范围(VLOOKUP(A13,$B$2:$D$8,3,0) ):指定了查找目标,如果没有说从哪里查找,EXCEL肯定会很为难。所以下一步我们就要指定从哪个范围中进行查找。VLOOKUP的这第二个参数可以从一个单元格区域中查找,也可以从一个常量数组或内存数组中查找。

          本例中要从表一中进行查找,那么范围我们要怎么指定呢?这里也是极易出错的地方。大家一定要注意,给定的第二个参数查找范围要符合以下条件才不会出错:

    • 查找目标一定要在该区域的第一列。本例中查找表二的姓名,那么姓名所对应的表一的姓名列,那么表一的姓名列(列)一定要是查找区域的第一列。像本例中,给定的区域要从第二列开始,即$B$2:$D$8,而不能是$A$2:$D$8。因为查找的“姓名”不在$A$2:$D$8区域的第一列。

    • 该区域中一定要包含要返回值所在的列,本例中要返回的值是年龄。年龄列(表一的D列)一定要包括在这个范围内,即:$B$2:$D$8,如果写成$B$2:$C$8就是错的。

          返回值的列数(B13 =VLOOKUP(A13,$B$2:$D$8,3,0))。这是VLOOKUP第3个参数。它是一个整数值。它怎么得来的呢。它是“返回值”在第二个参数给定的区域中的列数。本例中我们要返回的是“年龄”,它是第二个参数查找范围$B$2:$D$8的第3列。

          这里一定要注意,列数不是在工作表中的列数(不是第4列),而是在查找范围区域的第几列。如果本例中要是查找姓名所对应的性别,第3个参数的值应该设置为多少呢。答案是2。因为性别在$B$2:$D$8的第2列中。

          精确OR模糊查找(VLOOKUP(A13,$B$2:$D$8,3,0) ),最后一个参数是决定函数精确和模糊查找的关键。精确即完全一样,模糊即包含的意思。第4个参数如果指定值是0或FALSE就表示精确查找,而值为1或TRUE时则表示模糊。

          这里小编提醒大家切记切记,在使用VLOOKUP时千万不要把这个参数给漏掉了,如果缺少这个参数默为值为模糊查找,我们就无法精确查找到结果了。

    02

    VLOOKUP的反向查找

          VLOOKUP的反向查找,需要用IF函数把数据源倒置一下。一般情况下,VLOOKUP函数只能从左向右查找。但如果需要从右向右查找,则需要把区域进行“乾坤大挪移”,把列的位置用数组互换一下。

          例:要求在如下图所示表中的姓名反查工号。

    e5451960f06d58c17408b9039943ed95.png

          公式:

          =VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)

          公式剖析:

    • 这里其实不是VLOOKUP可以实现从右至左的查找,而是利用IF函数的数组效应把两列换位重新组合后,再按正常的从左至右查找。

    • IF({1,0},B2:B5,A2:A5)这是本公式中最重要的组成部分。在EXCEL函数中使用数组时(前提是该函数的参数支持数组),返回的结果也会是一个数组。这里1和0不是实际意义上的数字,而是1相关于TRUE,0相当于FALSE,当为1时,它会返回IF的第二个参数(B列),为0时返回第二个参数(A列)。根据数组运算返回数组,所以使用IF后的结果返回一个数组(非单元格区域):{'张一','A001';'赵三','A002';'杨五','A003';'孙二','A004'}

    03

    VLOOKUP的模糊查找

          模糊查找就是匹配查找。在A列我们知道如何查找型号为“AAA”的产品所对应的B列价格,即:=VLOOKUP(C1,A:B,2,0)

          如果需要查找包含“AAA”的产品名称怎么表示呢?如下图表中所示。

    2ade9c1b6a42238f7d3ca54072d9a9d8.png

          公式=VLOOKUP('*'&A10&'*',A2:B6,2,0)

          公式说明:VLOOKUP的第一个参数允许使用通配符“*”来表示包含的意思,把*放在字符的两边,即'*' & 字符 & '*'。

    04

    VLOOKUP的区间查找

          数字的区间查找即给定多个区间,指定一个数就可以查找出它在哪个区间并返回这个区间所对应的值。

          VLOOKUP的第4个参数,如果为0或FALSE是精确查找,如果是1或TRUE或省略则为模糊查找,那么实现区间查找正是第4个参数的模糊查找应用。

          首先需要了解一下VLOOKUP函数模糊查找的两个重要规则:

    • 引用的数字区域一定要从小到大排序。杂乱的数字是无法准确查找到的。如下面A列符合模糊查找的前题,B列则不符合。

    • 模糊查找的原理是:给一定个数,它会找到和它最接近,但比它小的那个数。详见下图说明。

          最后看一个实例:

          例:如下图所示,要求根据上面的提成比率表,在提成表计算表中计算每个销售额的提成比率和提成额。

    5a40da28e1ebc8eda623d3705ed0d041.png

          公式:=VLOOKUP(A11,$A$3:$B$7,2)

          公式说明:

    • 上述公式省略了VLOOKUP最后一个参数,相当于把第四个参数设置成1或TRUE。这表示VLOOKUP要进行数字的区间查找。

    • 图中公式中在查找5000时返回比率表0所对应的比率1%,原因是0和10000与5000最接近,但VLOOKUP只选比查找值小的那一个,所以公式会返回0所对应的比率1%。

    05

    VLOOKUP的多条件查找

          VLOOKUP函数需要借用数组才能实现多条件查找。例:要求根据部门和姓名查找C列的加班时间。

    377ab4a8fc8288283d24967b3960fd8e.png

          分析:不是让VLOOKUP本身实现多条件查找,而是想办法重构一个数组。多个条件可以用&连接在一起,同样两列也可以连接成一列数据,然后用IF函数进行组合。

          公式:

    {=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}

          公式剖析:

    • A9&B9 把两个条件连接在一起。把他们做为一个整体进行查找。

    • A2:A5&B2:B5,和条件连接相对应,把部分和姓名列也连接在一起,作为一个待查找的整体。

    • IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把连接后的两列与C列数据合并成一个两列的内存数组。

          按F9后可以查看的结果为:

          {'销售张一',1;'销售赵三',5;'人事杨五',3;'销售赵三',6}

          完成了数组的重构后,接下来就是VLOOKUP的基本查找功能了,另外公式中含有多个数据与多个数据运算(A2:A5&B2:B5),所以必须以数组形式输入,即按ctrl+shift后按ENTER结束输入。

    06

    VLOOKUP的多项查找

          VLOOKUP一般情况下只能查找一个,那么多项该怎么查找呢?例3 要求把如图表中所有张一的消费金额全列出来。

    57901b550808298d3e795cf8d188c22c.png

          分析:经过前面的学习,我们也有这样一个思路,我们在实现复杂的查找时,努力的方向是怎么重构一个查找内容和查找的区域。要想实现多项查找,我们可以对查找的内容进行编号,第一个出现的是后面连接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,)}

          公式剖析:

    • B$9&ROW(A1) 连接序号,公式向下复制时会变成B$9连接1,2,3

    • 给所有的张一进行编号。要想生成编号,就需要生成一个不断扩充的区域(INDIRECT('b2:b'&ROW($2:$6)),然后在这个逐行扩充的区域内统计“张一”的个数,在连接上$B$2:$B$6后就可以对所有的张一进行编号了

    • IF({1,0}把编号后的B列和C组重构成一个两列数组

          通过以上的讲解,需要知道,VLOOKUP函数的基本用法是固定的,要实现高级查找,就需要借助其他函数来重构查找内容和查找数组。

    CPDA数据分析师第五期在线学习班重磅上线啦!

    你还在等什么3de13615d442105c8d47e6bcef8fabc1.png3de13615d442105c8d47e6bcef8fabc1.png3de13615d442105c8d47e6bcef8fabc1.png

    7b43bdbbcee41290c0f8b858d19a02ed.png
    展开全文
  • 课件下载:https://share.weiyun.com/nPTXjSVl关注公众号,观看视频解析:之前我们讲过数据库函数,链接:数据库函数使用方法集合这个DGET属于数据库函数一种,这个函数能够解决问题:1,反向查找更加简单,和INDEX+...
  • 这篇文章为朋友们分享Vlookup函数的三种偏门用法。一.Vlookup函数实现动态求和:1.动态效果图:2.操作方法:(1)在J2单元格通过数据验证制作一个简单的下拉列表,方便选择不同的姓名。(2)在K2单元格输入公式=SUM...
  • 1、XLOOKUP基础语法在学习任何一个函数之前,需要了解这个函数的基础语法,从微软官方的帮助文档里找到了这个函数的参数语法,共计有5个参数,跟LOOKUP的参数非常接近,但是使用起来会更加简单了一些。其中第1~3个...
  • string类正向和反向查找

    千次阅读 2013-08-24 22:54:59
     其中s表示待查找的字符串,s0表示需要查找的子字符串,两个函数的返回值均为首次找到子串时,子串的  首字符在原待查找字符串中的位置。 2、用法举例: #include #include using namespace std; int main(){
  • #Excel#大家好,上篇文章对Excel数组做了...数据区域位置互换2.VLOOKUP函数反向操作3.VLOOKUP函数多条件查找1.数据区域位置互换如图所示,我们想到通过函数达到两列数据位置互换效果。在Excel中数字1表示条件成立...
  • 本文转载自... string中 find()应用 (rfind()类似,只是从反向查找) 原型如下: (1)size_t find (const string& str, size_t pos =0) const; //查找对象--string类对象 (2)siz...
  • 在APK中找到JNI函数签名,并将其应用于反向工具。 基本用法 使用生成signature.json 将signature.json加载到Ghidra / IDA / Radare2中 JadxFindJNI.jar 建造: $ make jni 或者,您可以只下载。 用法: $ java -...
  • 多种方法搞定反向查找

    千次阅读 2017-08-21 09:38:30
    Vlookup作为查找函数神器,相信很多职场人都用过,但它有个小缺点,只能找查找字段右侧数据,在查找字段左侧数据,一找就报错。什么都不说,上图验证 2. Vlookup函数有四个参数:第一个参数是要查找字段...
  • VLOOKUP之全面掌握VLOOKUP函数各类用法(一)

    万次阅读 多人点赞 2018-07-04 21:53:00
    本周将会给大家持续分享VLOOKUP函数的各类用法,目录如下:VlOOKUP基本用法第四个参数为1时的用法解析查询过程中错误值的处理顺序一致查询多列结果顺序不一致查询多列结果多条件查找反向查找返回多条记录① VLOOKUP...
  • Hello,大家好,今天跟大家整理了8种vlookup函数的使用方法,如果知道5种以上对于vlookup这个函数来说你就已经是大神了,话不多说,我们直接开始吧一、 常规用法公式:=VLOOKUP(F3,B2:D13,2,FALSE)二、 反向查找公式...
  • Hello,大家好,今天跟大家整理了8种vlookup函数的使用方法,如果知道5种以上对于vlookup这个函数来说你就已经是大神了,话不多说,我们直接开始吧一、 常规用法公式:=VLOOKUP(F3,B2:D13,2,FALSE)二、 反向查找公式...
  • string中 find()应用 (rfind() 类似,只是从反向查找) 原型如下: (1)size_t find (const string& str, size_t pos = 0) const; //查找对象--string类对象 (2)size_t find (const ch
  • 作为Excel中最重要的函数之一,Vlookup函数各种各样的用法,让我们在查询数据时得到极大的快捷和便利。<Vlookup函数>用途:用通俗的话就是根据现有条件查找到符合条件的值再黏贴过来。语法:Vlookup(查询值,...
  • string中 find()应用 (rfind()类似,只是从反向查找) 原型如下: (1)size_t find (const string& str, size_t pos =0) const; //查找对象--string类对象 (2)size_t find (const char* s, size_t ...
  • Hello,大家好,今天跟大家整理了8种vlookup函数的使用方法,如果知道5种以上对于vlookup这个函数来说你就已经是大神了,话不多说,我们直接开始吧一、 常规用法公式:=VLOOKUP(F3,B2:D13,2,FALSE)二、 反向查找公式...
  • 1.用法错误根据左边销售明细表查询年终奖3种最常用错误用法,还有1个反向查找案例。01 区域没锁定,特别是新手,经常犯这种错误。=VLOOKUP(F2,A1:D9,4,0)下拉时候就变成了区域就自动改变,从而出错。锁定区域...
  • ExcelHome论坛和QQ学习群、微信学习群里,一个刚刚诞生在襁褓中的新函数,凭借着大哥VLOOKUP和二哥LOOKUP的名声火了一把,来看看这个函数的微软帮助文件界面吧:老祝看了一下,大致的用法是:=XLOOKUP(查找内容,...
  • 笔记

    2020-12-21 22:17:24
    find函数的用法: 作用:查找从指定位置开始出现的目标字符串,返回对应位置 使用:1基础用法: int ans = s1.find(s2) ; //在S1中查找子串S2 2进阶用法: int ans = s1.find(s2, 2) ; //从S1的第二个字符开始查找...
  • Longest Consecutive Sequence 首先补充一些map的用法begin,end,rbegin,rend,empty,clear,size,max_size 八个常用的函数.map.begin();... 查找函数map.rebgin()和.rend()是反向遍历数据的起始位置和终止位置
  • shell 脚本编程

    2019-09-17 15:41:07
    函数的高级用法3. 文件查找命令高级用法find 命令2. locate3. whereis4. 文本处理grep sed awk1. grep过滤器2. sed 流编辑器1. 常用编辑命令(也就是command)2. 反向引用3. 修改命令4. 匹配模...
  • 14 printf函数的用法示例 2.6.2 示例程序序号 程序说明 对应章节 15 用imwrite函数生成png透明图 3.1.8 16 综合示例程序:图像的载入、显示与输出 3.1.9 17 为程序界面添加滑动条 3.2.1 18 鼠标操作示例 3.3 19 基础...

空空如也

空空如也

1 2 3
收藏数 41
精华内容 16
关键字:

反向查找函数的用法