小编看了一下,如果根据时间的大小来判...
学员的问题,2020年10月20日已经收过了,那么现在我要收2021年的1月21日的款项了,我要怎么才能做到它们自动往下催收呢?
小编看了一下,如果根据时间的大小来判断根本无从下手。转念一想,G5这个单元格有日期,下一个要催收的自然是B6这个单元格的日期,也就是相差一行。
这样就将问题转变成判断G列最后一个非空单元格再加1行。
我们知道LOOKUP函数有一个特点,如果有多个对应值,返回最后一个对应值,用在这里刚好。
最后一次收的日期就可以知道了。
=LOOKUP(1,0/(G4:G15<>””),B4:B15)
那怎么获取这个日期的下一个单元格呢?
这时就用到了区域错位引用,两边的区域相差一行。普通情况下,区域错位结果基本都是错的,而这里偏偏要错位,才是对的。
=LOOKUP(1,0/(G4:G15<>””),B5:B16)
想全面了解Lookup函数,必须要懂二分法
当你懂了lookup的查找原理,才能更好的使用它。二分法原理,一起学习一下。 从一个例子说起: 【例】下图中两个表只有第5行的会员名字有差异,在查找B的消费金额时,显示结果却不同,而左边直接出现A的消费金额。 公式展示: B11 =LOOKUP(A11,A2:B8) E11 =LOOKUP(D11,D2:E8
本来到这里问题就解决了,学员又提出了一个新问题,已经收款了,但是还有欠款金额,这种情况要继续催收同一行的日期。
现在问题就变成了判断I列第一个不是0的金额,对应的日期。
查找首次出现的,可以用INDEX MATCH数组,按Ctrl Shift Enter三键结束。
=INDEX(B4:B15,MATCH(1,–(I4:I15>0),0))
I4:I15>0,判断是否大于0,满足条件就显示TRUE,不满足就显示FALSE。
–(I4:I15>0),将TRUE转换成1,FALSE转换成0。
MATCH(1,–(I4:I15>0),0),用1查找1首次出现的位置,嵌套INDEX就是将位置转换成对应值。
也可以用INDEX MIN IF组合,这个就是先用MIN IF获取最小的行号,然后嵌套INDEX返回行号的对应值。
=INDEX(B:B,MIN(IF(I4:I15>0,ROW(4:15))))
每个疑难,正常都会有多种解决的方法,用你最拿手的方法。
玩转Lookup函数,看这一篇就够了……
今天分享一个Excel中非常强大的查找函数Lookup。在日常工作中,我们都会遇到在数据表中查询数据的需求,Excel中对数据查询给出了很多的方式,其中速度最快的查询当属LOOKUP函数,下面就让一点IT技术带你深入了解LOOKUP函数。 LOOKUP函数可以这样用哦: LOOKUP(查找值,查找值所在区域,返回的