多模块查找指定结果

问题:黄色区域输入结果,分别查找满两个条件在三个模块中的值,最后相加 

函数公式解决:

=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))))) 
posted @ 2023-10-08 15:11  熬肥妖  阅读(8)  评论(0编辑  收藏  举报