分享

小心!别被这个Excel函数,拖慢了你的excel表格

 li7486 2015-12-19

在excel2003版中,由于sumif函数和countif函数只能设置一个条件,一个神奇的多条件求和和计数函数走上了历史舞台,它就是:

Sumproduct函数

【例】如下图所示为销售明细表,要求在G3设置公式,统计出E3日期、商品名称为T的销售数量之和。

=SUMPRODUCT((A2:A100=E3)*(B2:B100=F3)*C2:C100)


Sumproduct函数后来被很多同学运用的炉火纯青,多条件求和变得不再是什么难题。兰色虽然知道这个函数运算速度慢,但一直也没觉得有什么,直到最近几个同学的提问,兰色才意识到这个函数的副作用有多么的大。

最近兰色在企业培训时,有几个同学说自已的表格运算非常的慢,不知道是什么原因。兰色打开表后发现,表中到处是Sumproduct函数设置的多条件求和公式。后来换成sumifs函数后,运算速度果然有所提升。

为了验证Sumproduct函数公式对表格运算速的影响,今天兰色特意做了2个相同的表格(源表样式同上图),同样有15000行源数据,分别设置同样数量的了10462个公式:

sumproudct函数公式

=SUMPRODUCT((Sheet1!$A$2:$A$15000=$A2)*(Sheet1!$B$2:$B$15000=B$1)*Sheet1!$C$2:$C$15000)

Sumifs函数公式:

=SUMIFS(Sheet1!$C:$C,Sheet1!$A:$A,汇总表!$A2,Sheet1!$B:$B,汇总表!B$1)


兰色用一段VBA代码进行了测试:


Sub 测试运算速度()
Dim t
t = Timer - t
Range('c1:c150') = Range('c1:c150').Value
MsgBox Timer - t

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多