Sumproduct
Basic Use | Advanced Use
To calculate the sum of the products of corresponding numbers in one or more ranges, use Excel's powerful SUMPRODUCT function.
Basic Use
1. For example, the SUMPRODUCT function below calculates the total amount spent.
data:image/s3,"s3://crabby-images/2d700/2d700308ef1069b3e2e19a0aeb13fa301b9b6630" alt="Sumproduct Function in Excel Sumproduct Function in Excel"
Explanation: the SUMPRODUCT function performs this calculation: (2 * 1000) + (4 * 250) + (4 * 100) + (2 * 50) = 3500.
2. The ranges must have the same dimensions or Excel will display the #VALUE! error.
data:image/s3,"s3://crabby-images/57552/57552329ba5a430db3b558e332da6dc9b40ce785" alt="Ranges of Unequal Size Ranges of Unequal Size"
3. The SUMPRODUCT function treats any entries that are not numeric as if they were zeros.
data:image/s3,"s3://crabby-images/02baf/02baf4b26619b87c6b8a12cdcf6681d70d076eec" alt="Non Numeric Entries Non Numeric Entries"
4. If you supply a single range, the SUMPRODUCT function produces the exact same result as the SUM function.
data:image/s3,"s3://crabby-images/99e32/99e3237a0756189f9d76191e085a6b8536369ac5" alt="One Range One Range"
Advanced Use
The SUMPRODUCT function is an extremely versatile function and can produce the same result as many built-in functions in Excel and even array formulas!
1a. For example, the COUNTIF function below counts the number of cells that contain exactly star.
data:image/s3,"s3://crabby-images/daabd/daabde9b1485191c53c13d35e1abcb08254e7883" alt="Countif Function Countif Function"
1b. The SUMPRODUCT function below produces the exact same result.
data:image/s3,"s3://crabby-images/9e259/9e259f789a2343342326f6d332ff7e395acfeb26" alt="Double Negative Double Negative"
Explanation: --(A1:A7="star") reduces to the following array constant:
--{TRUE;FALSE;FALSE;FALSE;FALSE;TRUE;FALSE}
The double negative -- coerces these Booleans to 1's and 0's (TRUE=1, FALSE=0). Result:
{1;0;0;0;0;1;0}
This array constant is used as an argument for the SUMPRODUCT function, giving a result of 2.
1c. The COUNTIF function below counts the number of cells that contain exactly star + 1 character. A question mark (?) matches exactly one character.
data:image/s3,"s3://crabby-images/88a59/88a59f4d41c13521bad89e61199cc4e25c7e85e1" alt="Wildcard Character Wildcard Character"
1d. The SUMPRODUCT function is not perfect! You cannot use wildcard characters (? and *) when you use the SUMPRODUCT function.
data:image/s3,"s3://crabby-images/092c0/092c02e100acf3421c7cfc1355fdb0f904cad81f" alt="Sumproduct Limitation Sumproduct Limitation"
2a. The array formula below counts the number of characters in a range of cells.
data:image/s3,"s3://crabby-images/5e8dc/5e8dc5ee24f54831b0d58e0c2f6e0364754fd121" alt="Count Characters Count Characters"
Note: finish an array formula by pressing CTRL + SHIFT + ENTER. Excel adds the curly braces {}.
2b. The SUMPRODUCT function below produces the exact same result.
data:image/s3,"s3://crabby-images/4896a/4896a47d12cce2fb9fed1eba4a948713212f2478" alt="Elegant Sumproduct Formula Elegant Sumproduct Formula"
Note: the array constant {9;4;6;5} is used as an argument for the SUMPRODUCT function, giving a result of 24. The SUMPRODUCT function handles arrays natively so you don't have to finish by pressing CTRL + SHIFT + ENTER. This is one of the biggest advantages of the SUMPRODUCT function because the curly braces {} confuse many Excel beginners!
3a. The array formula below sums the sales in 2018.
data:image/s3,"s3://crabby-images/82aab/82aabc7929b60ecfc291fdc077a0675b295faf9a" alt="Sum by Year Sum by Year"
3b. The SUMPRODUCT function below produces the exact same result.
data:image/s3,"s3://crabby-images/bafca/bafcae9f433c7407a5b50d9af812cbe79f9b722a" alt="Multiplication Operator Multiplication Operator"
Explanation: (YEAR(A1:A5)=2018)*B1:B5 reduces to:
({2018;2017;2018;2017;2017}=2018)*{10;1;7;20;3} and this reduces to:
{TRUE;FALSE;TRUE;FALSE;FALSE}*{10;1;7;20;3}
We don't need a double negative (see example 1b) because the multiplication operator * automatically coerces the Booleans to 1's and 0's (TRUE=1, FALSE=0). Result:
{10;0;7;0;0}
This array constant is used as an argument for the SUMPRODUCT function, giving a result of 17.
No comments:
Post a Comment