计算机二级函数lookup函数,Lookup函数“0/”结构的详细剖析

Lookup函数功能很强大,它可以区间查找、最后一个符合条件查找、多条件查找等。

【例】在G4中设置公式,根据G2的入库时间和G3的产品名称,从左表中查找对应的入库单价。

4d4e2c3b15878aceec727258a860e771.png

G2公式:

=LOOKUP(1,0/((B3:B8=G2)*(C3:C8=G3)),D3:D8)

有很多同学提问,为什么要用0/的结构?其实该结构广泛应用于lookup查找公式中,为了帮助同学们理解以便能灵活应用。今天就此进行详细的剖析:

首先,先看看(B3:B8=G2)*(C3:C8=G3)运算后是什么个结果?

在excel公式中如果:

A和B的值相等,=A=B 会返回结果True,True在四则运算中相于数字1

A和B的值不相等,=A=B 会返回结果False,False在四则运算中相于数字0

所以(B3:B8=G2)的结果是由false和true构成的一组值,如果放在单元格中,结果如F7:F12区域值所示:

1d8b73e6f9e16f45bdfd6ae991b8b568.png

同样(C3:C8=G3)的结果也是由True和Fasle组成的一组数值,而2个相同大小的一组值相乘,True*True=1,True*False=0,False*False=0,相乘的最终结果是由1和0组成的一组数。如下图 H7:H12 所示。

00b03b7e3de5f46140884d2300688fa3.png

由上图可以看出,相乘结果中值为1的行(H9所示),正是符合两个条件的行。那么怎么把这个1的位置提取出来呢?

Lookup函数的查找原理是二分法。按二分法原理,lookup函数会在在二分位处查找,要想准确查找到,这组值需要按升序排列,而只是公式(B3:B8=G2)*(C3:C8=G3)的结果是不符合要求的。

于是高手们想出了用0除的方法,把结果由1和0变成了由1和错误值构成的一组值。唯一符合条件的值为0,其他的均为错误值#DIV/0!

4f4202161b4eb03707fd6ffd2986843c.png

Lookup函数还有一个关键的特征,查找时可以忽略错误值,这样一组数值忽略后只剩下一个值,这时只需要使用任一个大于等于0的值查找即可。即:

=LOOKUP(1,0/((B3:B8=G2)*(C3:C8=G3)),D3:D8)

补充:0/的目的就是把符合条件的变成0,其他的变成错误值,利用lookup查找忽略错误值的特征查找到符合条件的值。

更多相关阅读

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值