Excel AGGREGATE Function Options
You see, the second argument of the AGGREGATE function is ‘Options’, which enables you to tell it how to handle hidden rows, error values, and nested SUBTOTAL and AGGERGATE functions by specifying an option number from the list below:
data:image/s3,"s3://crabby-images/75668/75668d7ea9a3c8a368abcd56528e3cfa8de9f730" alt="Excel AGGREGATE option numbers"
AGGREGATE can handle Arrays
AGGREGATE has two forms, Array 1 and Reference2. You’ll notice when you type in the function that you have a choice (kind of):
data:image/s3,"s3://crabby-images/9e8a1/9e8a1e9232756e4bfcd3c0f8de85d890e14d3554" alt="AGGREGATE function syntax"
The ‘form’ is dictated by the function_num you choose. Functions 1 to 13 are Reference form and 14 to 19 are array form.
AGGREGATE in Reference Form
Let’s look at how it compares to the SUM function, which means we’ll use the Reference form, as SUM is function_num 9.
The syntax:
=AGGREGATE(function_num, options, ref1, …)
My data is in an Excel
Table called ‘Table1’, so I’m using the table Structured References in my formula. e.g. Table1[Viewers] refers to cells C8:C19.
I’ve used Option number 5, which ignores hidden rows (which really means rows hidden by a filter as rows hidden manually are ALWAYS ignored). And you can see in the image below that when there are no rows hidden both
formulas return the same result (cells B4 and B5):
data:image/s3,"s3://crabby-images/0e325/0e325dc279b78aabc5ac8ee518f601ee7ce46861" alt="SUM with AGGREGATE function"
However when I hide some rows, by filtering out the South and West regions, my AGGREGATE formula returns a result that ignores the
hidden rows, whereas SUM still includes the hidden rows:
data:image/s3,"s3://crabby-images/71ad8/71ad82754bd24ff602fa4ff13a39331fd917837c" alt="SUM with AGGREGATE function ignore hidden rows"
AGGREGATE in Array Form
Similarly we can find the largest value in the Viewers column with function_num 14 for LARGE.
This means we’re using AGGREGATE in array form. And notice we also have an extra argument to
specify ‘k’, with 1 returning the largest, 2 returning the second largest and so on:
data:image/s3,"s3://crabby-images/cd4ff/cd4ff84a029c2c3f9062f125e186e69f4adf75f1" alt="LARGE array AGGREGATE function"
With no rows hidden LARGE and AGGREGATE return the same result (see below):
data:image/s3,"s3://crabby-images/774f7/774f7aa286a14980526f282a62b003dd48fe93c4" alt="LARGE array AGGREGATE function"
But with rows for West hidden we get different results with AGGREGATE, as you can see
below (note; I've used option number 5 - ignore hidden rows in AGGREGATE):
data:image/s3,"s3://crabby-images/b02ff/b02fff027351fbb9bb737e5247925c090b821799" alt="LARGE array AGGREGATE hidden rows"
Tip: with dynamic arrays we can also use AGGREGATE to
spill results. For example, let's say we want to return the top 2 results. We can use this formula:
=AGGREGATE(14,5,Table1[Viewers],{1;2})
Exploiting Option 6 – Ignore Hidden Rows and Error Values
So far, we’ve only looked at Option
number 5, which ignores hidden rows. Option number 6 allows us to ignore error values, and we can use this to our advantage to only aggregate values that meet a certain condition, or criteria.
For example, let’s say we want to identify the smallest value that's greater than the average of the entire list. With AGGREGATE we can use the SMALL function_num 15, like so:
data:image/s3,"s3://crabby-images/141ee/141eea9acf21d1926b563ba6f0d7a68aa7710ac3" alt="AGGREGATE 2nd smallest above average"
Let’s take a closer look at this formula above and how it evaluates:
=AGGREGATE(15,6,Table1[Viewers]/(Table1[Viewers]>AVERAGE(Table1[Viewers])),1)
The array argument takes the values in the Viewers column and then uses Boolean logic
Table1[Viewers]>AVERAGE(Table1[Viewers]) to test if the values are above average.
When Table1[Viewers]>AVERAGE(Table1[Viewers]) is evaluated it returns a series of TRUE and FALSE values like
this:
=AGGREGATE(15,6,Table1[Viewers]/{FALSE;FALSE;FALSE;FALSE;FALSE;TRUE;FALSE;FALSE;TRUE;TRUE;TRUE;TRUE},1)
In Excel when a math operation is performed on a logical value (TRUE or FALSE), they are converted to their numeric equivalent of 1 and 0.
So when the Table1[Viewers] array is
expanded Excel divides them by the values in the logical test array which converts them to 1 and 0:
=AGGREGATE(15,6, {91;87;99;102;125;140;107;133;138;172;206;240}/ {0;0;0;0;0;1;0;0;1;1;1;1},1)
And when we divide anything by zero we get an error, so our formula is littered with #DIV errors for values in the Viewers column where the values is below
average, like this:
=AGGREGATE(15,6,{#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;140;#DIV/0!;#DIV/0!;138;172;206;240},1)
Have you worked out where I’m going with this? Remember the Option number argument of 6 ignores errors, so AGGREGATE now looks like this with all the #DIV errors gone:
=AGGREGATE(14,6,{140;138;172;206;240},1)
And the smallest value is:
=138
If the concept of arrays is hurting your head and you want to learn more about array formulas (I don’t know, you might be a glutton for punishment ;-)), then check my Advanced Excel Formulas
Course.
AGGREGATE Notes:
- As with many Excel functions, AGGREGATE is designed to work with data in columns, so when you reference a horizontal range, AGGREGATE will not ignore values in hidden columns. It only ignores hidden rows in a vertical range.
- You might have noticed
AGGREGATE is similar to the SUBTOTAL function in that it can perform a range of different calculations, and you’d be right, but I’m sure you’ll agree that AGGREGATE is much more powerful.
- AGGREGATE will not ignore filtered
rows, nested subtotals or nested aggregates if the array argument includes a calculation, as it does in the last example (=AGGREGATE(15,6,Table1[Viewers]/(Table1[Viewers]>AVERAGE(Table1[Viewers])),2). i.e. option numbers 0 through 5 and 7 will not ignore filtered rows.
- AGGREGATE will not ignore rows hidden manually using the right-click > hide. If this is required, use the SUBTOTAL function.