excel函数技巧:map+filter统计不同人的在岗时长-趣帮office教程网

如图,ABC三列为原始列,记录员工上班打卡的时间,其中每天打卡的次数并不一致,想要求得张三总的工作时长,公式如下:

=LET(x,UNIQUE(FILTER(B:B,A:A=A2)),SUM(MAP(x,LAMBDA(m,LET(s,FILTER(C:C,(A:A=A2)*(B:B=m)),MAX(s)-MIN(s)))))*24)

公式思路:

将公式注释一下:

=LET(x,UNIQUE(FILTER(B:B,A:A=A2)),------

设变量x,列举出打卡的每一天并去除重复值。

SUM(

MAP(x,LAMBDA(m,LET(s,FILTER(C:C,(A:A=A2)*(B:B=m)),MAX(s)-MIN(s))))---

以张三的每一天为初始条件,遍历每一天,找出每天的所有打卡时间,并用最大-最小得到上班时间。

)*24------

每天的时间相加得到以天为单位的工作时间,再乘以24就得到以小时为单位的工作时间,这就是最终想要的结果 。

)

lambda函数变核心的变革即是变量,对变量进行遍历最终得出结果,这是函数式编程的思想,会从根本上改变execel函数的使用方法和思维。mapreducescanbyrow等等都是与lambda搭配的函数,它们在一起能够解决以前只能用辅助列才能得出的结果,由半自动的办公,变成完成自动化的办公。