多模块查找指定结果
问题:黄色区域输入结果,分别查找满两个条件在三个模块中的值,最后相加
函数公式解决:
=SUM(N(INDIRECT(TEXT(FILTER(ROW($1:$20),$A$1:$A$20=$J2)*100+MOD(SMALL(IF($B$1:$F$20=K$1,ROW($1:$20)*100+COLUMN($B:$F)),ROW($1:$3)),100),"r0c00"),)))
以A01和C1为例
IF($B$1:$F$20=K$1,ROW($1:$20)*100+COLUMN($B:$F))部分找出B:F中C1所在位置的行数和列数
用Small从小大到提取出来,目的不仅为提取出对应行列数,还要按行的从小到大的顺序排列
用Mod去掉行部分的值
FILTER(ROW($1:$20),$A$1:$A$20=$J2)*100部分列出满条件是A01的行数,乘以100以后再加上上术列值,得出每个满足条件A01和C1的结果所在的行列数
用Text将其格式化成R0C00结构
用Indirect间接引用这一结果
用N函数将间接引用的多维引用结果转成一列三行的内存数组
用Sum将三个数相加得到最终结果
在Excel中可以使用以下公式:
=SUM((CHOOSEROWS($B$1:$F$20,ROW($1:$3)*7-6)=K$1)*FILTER($B$1:$F$20,$A$1:$A$20=$J2))
=SUM(MAP(FILTER(ROW($1:$19),$A$2:$A$20=$J2),TOCOL(IF($B$1:$F$20=K$1,SEQUENCE(,5),1/0),2),LAMBDA(r,c,SUM(INDEX($B$2:$F$20,r,c)))))