ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: gdliyy

[原创]关于用SUMPRODUCT取代SUM数组公式的想法

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2005-5-12 15:11 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖已被收录到知识树中,索引项:SUMPRODUCT
以下是引用gdliyy在2005-5-12 13:17:00的发言: >

呵呵~~~谢谢指正,原来是想表达这个行列数的意思的,只是当时表达错误!

但对于第1个提法我还是有不同的意见: 1、如我之前讨论的问题中的例子:=Sum(if(A1:C10="A",B1:D10)*E1:E10),在这个例子中,显然B1:D10中可能含有文本,所以不能直接相乘,必须用IF加以判断,在这样的核心表达式不修改的情况下,不管你是用Sum还是用Sumproduct来外套,都必须用三键来结束的;但是当我们合理地运用一下Sumproduct的优势,公式稍修改也可回车结束的。 2、但对于这样的一些公式,当IF条件用来屏蔽错误值的时候,那你用Sumproduct()来单键结束来代替也是无效的,必须使用数组公式三键结束。

我没找到你说的例子,请你先看一例,再请你看看你的帖子中的例子是否也能用相同的解法

xkMsoruH.rar (2.56 KB, 下载次数: 122)

{=SUM(IF($B$4:$F$6=A17,$C$4:$G$6)*$B$10:$B$12)}

V.s

=SUMPRODUCT(($B$4:$F$6=A17)*$B$10:$B$12,$C$4:$G$6)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2005-5-12 23:26 | 显示全部楼层
以下是引用apolloh在2005-5-12 15:11:00的发言: >

我没找到你说的例子,请你先看一例,再请你看看你的帖子中的例子是否也能用相同的解法

其实你的这个例子与我第1条说的是一样的,这个例子当然可以的!

另外第2点可能表述得还不准确!“2、但对于这样的一些公式,当IF条件用来屏蔽错误值的时候,那你用Sumproduct()来单键结束来代替也是无效的,必须使用数组公式三键结束。” 这样说更准确一些:对于有些公式,当IF函数是用来屏蔽错误值时,如果你试图简化IF段,用Sumproduct()来代替Sum()可能是徒劳的,因为Sumproduct()只能忽略非数值普通数据,但是不能忽略错误值的,因此你同样还得使用IF函数,最终必须使用数组公式三键结束编辑。

看看下面这个例子呢?可能这个例子举得不太恰当,但仅此表达我的意思,黄兄应该理解的,不好意思了!:)

ZCGxHznA.zip (2.69 KB, 下载次数: 115)

TA的精华主题

TA的得分主题

发表于 2005-5-13 00:00 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
=SUMPRODUCT(IF($B$4:$F$6=A17,$C$4:$G$6)*$B$10:$B$12) 这样的公式必须用数组公式方式输入是因为IF的条件引用了多个单元格,如果不用数组公式方式输入excel就自动以“隐含的交叉引用”来代替多个单元格引用$B$4:$F$6,而事实上公式所在格的行是不与这个区域相交的(因为区域是多行列的,在同一工作表中根本不可能交叉),那样IF的条件就是错误,IF返回的结果也是错误,最后公式的结果也是错误! 如果以数组公式的方式输入,excel必定不用隐含交叉的,那样就是一个正常的数组运算。
[此贴子已经被作者于2005-5-13 0:03:12编辑过]

TA的精华主题

TA的得分主题

 楼主| 发表于 2005-5-13 00:45 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

呵呵~~~Chenjun兄所表述的,应该与我和黄兄所要讨论的不同吧!不过这个也是初学者不容易理解的一些常识性知识。

黄兄的见解是:所有的Sum(If(X1,X2)*X3)公式都可以用Sumproduct(X1*X3,X2)来代替,只要它们的数组尺寸相同。

TA的精华主题

TA的得分主题

发表于 2005-5-13 07:52 | 显示全部楼层

这个例子是特殊,不过确实说明了你的观点。

不过你说的情况我可以再给一个不用数组公式三键结束的例子,但有无此必要就应该考虑了。:)

=SUMPRODUCT(($B$4:$F$6=A17)*$B$10:$B$12,RIGHT(N(OFFSET($C$4,ROW($C$4:$G$6)-ROW($C$4),COLUMN($C$4:$G$6)-COLUMN($C$4))))*1)

w3RkCTV0.rar (4.83 KB, 下载次数: 126)

另老大,你说的情况在=SUMPRODUCT(($B$4:$F$6=A17)*$B$10:$B$12,$C$4:$G$6) 中应该不会发生的,因为没有用IF。

[此贴子已经被作者于2005-5-13 8:40:10编辑过]

TA的精华主题

TA的得分主题

发表于 2005-5-13 10:20 | 显示全部楼层
以下是引用gdliyy在2005-5-12 13:17:00的发言: >

呵呵~~~谢谢指正,原来是想表达这个行列数的意思的,只是当时表达错误!

但对于第1个提法我还是有不同的意见: 1、如我之前讨论的问题中的例子:=Sum(if(A1:C10="A",B1:D10)*E1:E10),在这个例子中,显然B1:D10中可能含有文本,所以不能直接相乘,必须用IF加以判断,在这样的核心表达式不修改的情况下,不管你是用Sum还是用Sumproduct来外套,都必须用三键来结束的;但是当我们合理地运用一下Sumproduct的优势,公式稍修改也可回车结束的。 2、但对于这样的一些公式,当IF条件用来屏蔽错误值的时候,那你用Sumproduct()来单键结束来代替也是无效的,必须使用数组公式三键结束。

我解释的不是你们的附件中的公式,是上面第2点的原因。

TA的精华主题

TA的得分主题

发表于 2005-5-13 10:29 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2005-5-18 16:51 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2005-5-19 18:07 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2005-5-26 11:33 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-27 09:23 , Processed in 0.039999 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表