SUMPRODUCT函数返回相应范围或数组的个数之和。 默认操作是乘法,但也可以执行加减除运算。

本示例使用 SUMPRODUCT 返回给定项和大小的总销售额:

使用 SUMPRODUCT 函数返回总销售额的示例(提供每个产品名称、大小和单个销售值)。

SUMPRODUCT 匹配项 Y/大小 M 的所有实例并求和,因此对于此示例,21 加 41 等于 62。

语法

若要使用默认操作 (乘法) :

=SUMPRODUCT (array1, [array2], [array3], ...)

SUMPRODUCT 函数语法具有下列参数:

参数

说明

array1   

必需

其相应元素需要进行相乘并求和的第一个数组参数。

[array2], [array3],...    

可选

2 到 255 个数组参数,其相应元素需要进行相乘并求和。

执行其他算术运算

像往常一样使用 SUMPRODUCT,但请将分隔数组参数的逗号替换为所需的算术运算符 (*、/、+、-) 。 执行所有操作后,结果将像往常一样进行求和。

注意: 如果使用算术运算符,请考虑将数组参数括在括号中,并使用括号对数组参数进行分组以控制算术运算的顺序。

备注

  • 数组参数必须具有相同的维数。 否则,函数 SUMPRODUCT 将返回 #VALUE! 错误值 #REF!。 例如,=SUMPRODUCT (C2:C10,D2:D5) 将返回错误,因为范围的大小不同。

  • SUMPRODUCT 将非数值数组条目视为零。

  • 为获得最佳性能,SUMPRODUCT 不应与完整列引用一同使用。 请考虑 =SUMPRODUCT (A:A,B:B) ,在此函数将 A 列中的 1,048,576 个单元格乘以 B 列中的 1,048,576 个单元格,然后再添加它们。 

示例 1

SUMPRODUCT 函数的示例,用于在提供单位成本和数量时返回所售项的总和。

若要使用上面的示例列表创建公式,请键入 =SUMPRODUCT (C2:C5,D2:D5) 并按 Enter。 列 C 中的每个单元格乘以 D 列中同一行中的对应单元格,结果将相加。 杂货的总量为 $78.97。

若要编写提供相同结果的较长公式,请键入 =C2*D2+C3*D3+C4*D4+C5*D5,然后按 Enter。 按 Enter 后,结果相同:$78.97。 单元格 C2 乘以 D2,其结果将添加到单元格 C3 乘以单元格 D3 的结果,以此类比。

示例 2

以下示例使用 SUMPRODUCT 按销售代理返回总净销售额,其中按代理计算总销售额和费用。 在这种情况下,我们将使用一个Excel表, 它使用结构化引用而不是标准引用Excel区域。 在这里,你将看到按名称引用"销售、支出"和"代理"范围。

SUMPRODUCT 函数的示例,当向每个销售代表提供销售和费用时,按销售代表返回总销售额。

公式为:=SUMPRODUCT ( ( (Table1[Sales]) + (Table1[Expenses]) ) * (Table1[Agent]=B8) ) ,它返回单元格 B8 中列出的代理的所有销售和费用的总和。

示例 3

此示例中,我们想要返回给定区域销售的特定商品的总数。 在这种情况下,东部区域销售了多少个水果?

使用 SUMPRODUCT 按区域返回项目总和的一个测试。 在这种情况下,在"东部"区域销售的蛋糕数量。

此处的公式为:=SUMPRODUCT ( (B2:B9=B12) * (C2:C9=C12) *D2:D9) 。 它首先将"东部"的出现次数乘以匹配切分次数。 最后,对"销售额"列中相应行的值进行汇总。 若要了解如何Excel,请选择公式单元格,然后转到"公式">"公式>计算"。

需要更多帮助吗?

你始终可以在 Excel 技术社区中咨询专家或在 Answers 社区获取

另请参阅

对单元格区域执行条件计算

使用 SUMIFS 基于多个条件求和

使用 COUNTIFS 基于多个条件进行计数

基于具有 AVERAGEIFS 的多个条件的平均值

需要更多帮助?

扩展你的技能
了解培训

此信息是否有帮助?

你对语言质量的满意程度如何?
哪些因素影响了你的体验?

谢谢您的反馈!

×