In statistic when calculating the total values for a range of numbers, we often count duplicate values only once. Normally, if only apply SUM function to calculate total values, it will cover all values including all duplicate values. So, we need to update the formula to make it meet our requirement. This free tutorial will show you the formula to sum values with duplicate values only once in the selected range.
Precondition:
See screenshot below. We want to sum all values but for the duplicate values, we only count once.
data:image/s3,"s3://crabby-images/499cb/499cb87bb7837605c40c5c6e6ecb0055571b6787" alt="How to Sum 1"
Table of Contents
1. Calculate Total Values with Counting Duplicate Values Only Once using Formula
Step1: In B7, enter the formula:
=SUMPRODUCT(A2:B6/COUNTIF(A2:B6,A2:B6))
In this formula, A2:B6 is the range selected for calculating.
data:image/s3,"s3://crabby-images/a58c8/a58c8a86d596f651a594f2e72dd971230e3794f1" alt="How to Sum 2"
Step2: Click Enter to get result. Verify that the sum value is calculated properly. Duplicate values like 100, 60 are only count once.
data:image/s3,"s3://crabby-images/bd8b9/bd8b9c65499967f66e7f5cf47f9fa1bc20c0c7fb" alt="How to Sum 3"
2. Calculate Total Values with Counting Duplicate Values Only Once using User Defined Function
You can create a User-Defined Function (UDF) in VBA to calculate the total values of a range while counting duplicate values only once. Here are the steps of how to do it:
Step1: press ALT + F11 to open the VBA editor in your workbook.
data:image/s3,"s3://crabby-images/a4668/a46682b50df0a006b440e5c5d93fa4cf8069bdc9" alt=""
Step2: In the editor, go to Insert > Module to create a new module.
data:image/s3,"s3://crabby-images/b66f9/b66f97d7985218a5d78535dfa45a6a88cb53e17a" alt=""
Step3: In the module, paste the following code. Save the module and go back to your Excel workbook.
data:image/s3,"s3://crabby-images/3a510/3a510dd78ec91678542540fe3c6f599323956243" alt="How to SumCalculate Total Values with Duplicate Values Only Once vba1.png"
Function SumUnique_ExcelHow(ByVal rng As Range) As Double
Dim dict As Object
Set dict = CreateObject("Scripting.Dictionary")
Dim cell As Range
For Each cell In rng
If Not dict.exists(cell.Value) Then
dict.Add cell.Value, 1
End If
Next cell
Dim key As Variant
For Each key In dict.keys
SumUnique_ExcelHow = SumUnique_ExcelHow + key
Next key
End Function
Step4: In any blank cell, enter the formula:
=SumUnique_ExcelHow(A2:B6)
Where A2:B6 is the range of values you want to calculate the total for.
data:image/s3,"s3://crabby-images/74b7d/74b7d25cbbcebdeab85d684bd01f9b60930f77ee" alt="How to SumCalculate Total Values with Duplicate Values Only Once vba2.png"
3. Video: Calculate Total Values with Counting Duplicate Values Only Once
This video will show you how to calculate total values with counting duplicate values only once using either the SUMPRODUCT function or a user-defined function with VBA code.
4. Related Functions
- Excel SUMPRODUCT function
The Excel SUMPRODUCT function multiplies corresponding components in the given one or more arrays or ranges, and returns the sum of those products.The syntax of the SUMPRODUCT function is as below:= SUMPRODUCT (array1,[array2],…)… - Excel COUNTIF function
The Excel COUNTIF function will count the number of cells in a range that meet a given criteria. This function can be used to count the different kinds of cells with number, date, text values, blank, non-blanks, or containing specific characters.etc.= COUNTIF (range, criteria)…