原帖由 jxt 于 2008-5-25 11:31 发表
能否解释一下书中技巧210,H10单元格:=SUMPRODUCT((B$4:B$12=G10)*C$3:E$3,SUMIF(G$2:G$5,C$4:E$12,H$2:H$5)),我是初学,希望会的帮我解释一下,谢谢!365723
[此贴子已经被作者于2008-5-26 10:48:04编辑过]
这种长函数公式,如果拆开看的话更容易理解
=SUMPRODUCT((B$4:B$12=G10)*C$3:E$3,SUMIF(G$2:G$5,C$4:E$12,H$2:H$5))
B$4:B$12=G10:
这句是判断B$4:B$12区域中哪些是属于部门A的,是则返回TRUE,否则返回 FALSE,因为B$4:B$12是一维数组的形式,返回的结果也是数组形式,结果是:{TRUE;FALSE;TRUE;FALSE;FALSE;TRUE;FALSE;FALSE;FALSE}
C$3:E$3 :
这句就是表示一个简单的一维数组,就是{0.5,0.3,0.2}
(B$4:B$12=G10)*C$3:E$3:
这是上面两数组相乘,结果当然是数组,因为B$4:B$12是行数组(垂直数组),C$3:E$3是列数组(水平数组),最终结果变成了二维数组:{0.5,0.3,0.2;0,0,0;0.5,0.3,0.2;0,0,0;0,0,0;0.5,0.3,0.2;0,0,0;0,0,0;0,0,0} 见图片相乘结果
SUMIF(G$2:G$5,C$4:E$12,H$2:H$5):
使用SUMIF条件求和,因为输入的参数是数组,当然结果也是返回的是数组了,结果是:{8,6,10;8,8,8;10,8,6;6,10,10;6,6,8;4,6,6;8,10,4;10,4,8;10,4,4} 见图片sumif
最后就是利用sumproduct函数了,就是将上面计算出的两个二维数组的对应项相乘然后在相加,
即=0.5*8+0.3*6+0.2*10+0*8+0*8+0*8.........0*10+0*4+0*8+0*10+0*4+0*4
数组解释起来较复杂,你可以在编辑栏中选中公式的某一项按F9,慢慢琢磨一下!
[ 本帖最后由 zhangyulei2470 于 2009-6-9 02:24 编辑 ] |