软件是一系列按照特定顺序组织的计算机数据和指令的集合。一般来讲软件被划分为编程语言、系统软件、应用软件和介于这两者之间的中间件。硬件是“计算机硬件”的简称。与“软件”相对,电子计算机系统中所有实体部件和设备的统称。
SUMPRODUCT函数的使用方法及实例详解(值得收藏)
今天和大家分享一个名字拖沓,但是应用非常广泛的函数——SUMPRODUCT函数。 开门见山,咱们通过几个例子,一起来看下SUMPRODUCT函数具体能干什么样的工作,本文通过几个实例详解比SUMIF好用十倍的函数——SUMPRODUCT函数的使用方法及实例。 假设上面这张图,是某个公司工资发放的部分记录表,A列是工资发放的时间,B列是员工所属的部门,C列是员工姓名,D列是相关员工领取的工资金额。 那么,问题来了: 一、西门庆同志领取了几次工资? 这是一个单条件计数的问题,通常我们使用COUNTIF函数,如果使用SUMPRODUCT函数,一般写成这样: =SUMPRODUCT((C2:C13="西门庆")*1) 先判断C2:C13的值是否等于”西门庆”,相等则返回TRUE,不等则返回FALSE,由此建立一个有逻辑值构成的内存数组,SUMPRODUCT有一个特性,它会将非数值型的数组元素作为0处理,逻辑值自然是属于非数值型的数组元素,我们使用*1的方式,把逻辑值转化为数值,TRUE转化为1,FALSE转化为0,最后统计求和。 二、西门庆同志一共领取了多少工资? 这是一个单条件求和的问题,通常我们使用SUMIF函数,如果使用SUMPRODUCT函数,我们可以写成这样: =SUMPRODUCT((C2:C13="西门庆")*D2:D13) 依然首先判断C2:C13的值是否等于”西门庆”,得到逻辑值FALSE或TRUE,再和D2:D13的值对应相乘,最后统计求和得出结果。 看完了上面两个问题,有些表亲心里就嘀咕了,貌似SUMPRODUCT能干的事,SUMIF和COUNTIF也能做到,而且做的更好,那么还要SUMPRODUCT干啥? 乡亲们呐,话不能这么说,SUMPRODUCT可是上得厅堂下得厨房,对工作环境不挑不拣,它对参数类型没有啥特别要求,COUNTIF和SUMIF就不同咧,他俩要求个别参数,必须是区域数组(Range),比如下面这两个问题,COUNTIF和SUMIF就犯难了。 三、六月份财务部发放了几次工资?累计发放了多少? 六月份财务部发放了几次工资,这是一个多条件计数的问题哈: 第一个条件,发放工资的时间必须是六月份; 第二个条件,发放工资的部门必须是财务部。 如果使用多条件计数函数COUNTIFS,判断发放工资的时间是否属于六月份,会简单问题复杂化。 而使用SUMPRODUCT函数,咱们可以简单利索的写成这样: =SUMPRODUCT((MONTH(A2:A13)=6)*(B2:B13="财务部")) 统计六月份财务部发放了多少工资? 表亲们都晓得,这是一个常见的多条件求和问题。如果使用SUMIFS函数,判断发放工资的时间是否属于六月份,和COUNTIFS类似,也会简单问题复杂化。 SUMPRODUCT跃然而至: =SUMPRODUCT((MONTH(A2:A13)=6)*(B2:B13="财务部"),D2:D13) 上面这个公式可以说是SUMPRODUCT多条件求和的典型用法啦,可以归纳为: =SUMPRODUCT((条件一)*(条件二)……,求和区域) 四、六月份财务部和市场部合计发放了多少工资? 通过上面第三个问题,表亲们已经晓得如何计算六月份财务部发了多少工资,那么六月份财务部和市场部合计发了多少工资,又当怎么计算呢? 我们经常见有些表亲把公式写成这样: =SUMPRODUCT((MONTH(A2:A13)=6)*(B2:B13="财务部")*D2:D13)+SUMPRODUCT((MONTH(A2:A13)=6)*(B2:B13="市场部")*D2:D13) 这些表亲们估计心想,不就是计算两个部门吗?甭说两个,二十个咱也能算,一个加一个,一直加到二十个,世上无难事,只怕有心人嘛…… 公式写的那么长,先不谈计算速度,首先它累手啊,其次万一写错了,要修改,那也是麻烦他妈哭麻烦——麻烦死了。 其实我们可以写成这样: =SUMPRODUCT((MONTH(A2:A13)=6)*(B2:B13={"财务部","市场部"})*D2:D13) 硬件是实在的,有模有样的。软件是程序性的。是一系列的指令。有了软件,硬件才会实现更丰富的功能。 |
温馨提示:喜欢本站的话,请收藏一下本站!