Handling Varying Array Sizes in COUNTIFS in Google Sheets

Published on

Are you seeing the “Array arguments to COUNTIFS are of different sizes” error in Google Sheets? This error occurs when you use varying array sizes in a COUNTIFS formula, as the function doesn’t support arrays of different sizes.

This issue typically arises when the columns specified in criteria_range1 and criteria_range2 have mismatched sizes.

It’s important to understand the function syntax:

Syntax: COUNTIFS(criteria_range1, criterion1, [criteria_range2, …], [criterion2, …])

When specifying multiple criteria ranges, the dimensions of the criteria ranges must be the same.

This means the number of rows and columns must match across all specified criteria ranges or arrays. Let’s look at an example to illustrate this:

=COUNTIFS(A2:D10, "Apple", E2:E10, "Yes")
Handling Varying Array Sizes in COUNTIFS and Error in Google Sheets

In this example, I want to count the occurrences of “Apple” in the multi-column range A2:D10 where the corresponding value in E2:E10 equals “Yes.” However, this returns a #VALUE! error.

In this formula, four arguments are in use:

  • criteria_range1 – A2:D10
  • criterion1 – “Apple”
  • criteria_range2 – E2:E10
  • criterion2 – “Yes”

As you can see, the two array arguments (criteria_range1 and criteria_range2) provided to COUNTIFS have different sizes.

The first array (criteria_range1) has four columns, while the second array (criteria_range2) has only one column.

I have three workaround formulas for you to try when you encounter the #VALUE! error due to varying array sizes in COUNTIFS, as described above.

Option 1: Expanding Criteria Range Dimensions

In our example, criteria_range1 (A2:D10) contains 4 columns, while criteria_range2 (E2:E10) contains 1 column.

To match the number of columns in criteria_range1, you need to expand criteria_range2 to 4 columns. You can achieve this by repeating the column multiple times using the SUBSTITUTE function as follows:

=ArrayFormula(SUBSTITUTE(E2:E10, "", SEQUENCE(1, 4)))

This formula repeats the values in E2:E10 across 4 columns (you can adjust the number of repetitions by changing the 4 in the SEQUENCE function to the desired number).

Use this adjusted range as criteria_range2 in your COUNTIFS formula:

=COUNTIFS(A2:D10, "Apple", ArrayFormula(SUBSTITUTE(E2:E10, "", SEQUENCE(1, 4))), "Yes")

Matching the criteria range dimensions is one way to handle varying array sizes in COUNTIFS. However, there are several alternative solutions. Below, you’ll find two of the best alternatives.

Option 2: Filtering a Multi-Column Range

You can achieve the desired result without matching varying array sizes in COUNTIFS as described above.

The goal is to count “Apple” in A2:D10 where E2:E10 is “Yes.” To do this, we’ll filter A2:D10 based on the condition in E2:E10, which allows us to avoid using criteria_range2.

Use the following formula:

=COUNTIFS(FILTER(A2:D10, E2:E10="Yes"), "Apple")

The FILTER function filters A2:D10 to include only the rows where E2:E10 equals “Yes.” Then, COUNTIFS is used to count the occurrences of “Apple” within the filtered range.

Option 3: Using an IF Logical Test

This approach is similar to Option 2. Instead of using FILTER, we will eliminate criteria_range2 using an IF logical test:

=COUNTIFS(ArrayFormula(IF(E2:E10="Yes", A2:D10,)), "Apple")

The formula ArrayFormula(IF(E2:E10 = "Yes", A2:D10,)) returns the values from A2:D10 where E2:E10 is equal to “Yes”; otherwise, it returns blank.

Within this multi-column range, COUNTIFS is used to count occurrences of “Apple.”

Handling Varying Array Sizes in COUNTIFS: Choosing the Best Option

Out of the three formulas, I would recommend Option 2. Option 1 may impact performance with large datasets. Option 2 is preferable to Option 3 as well, in terms of performance, since it operates on a smaller, filtered dataset rather than the entire range.

Resources

Prashanth KV
Prashanth KV
Your Trusted Google Sheets and Excel Guide Prashanth KV brings a wealth of experience in Google Sheets and Excel, cultivated through years of work with multinational corporations in Mumbai and Dubai. As a recognized Google Product Expert in Docs Editors, Prashanth shares his expertise through insightful blogging since 2012. Explore his blog for practical tips and guidance on maximizing your spreadsheet skills.

How to Extract Numbers from Text in Excel with Regex

You can use the REGEXEXTRACT or REGEXREPLACE functions to easily extract numbers from text...

Using OFFSET and MATCH Together in Google Sheets: Advanced Tips

One powerful and flexible way to look up values is by combining the OFFSET...

How to Use OFFSET and XMATCH Functions Together in Excel

We often use the OFFSET and XMATCH functions together to match a value in...

How to Calculate Maximum Drawdown in Excel and Google Sheets

You can use the following dynamic array formula to calculate maximum drawdown (MDD) in...

More like this

Using OFFSET and MATCH Together in Google Sheets: Advanced Tips

One powerful and flexible way to look up values is by combining the OFFSET...

Running Count with Structured References in Google Sheets

Running a count with structured references is achievable in Google Sheets tables using the...

Running Total with Structured Table References in Google Sheets

You can use two types of formulas to create a running total with structured...

LEAVE A REPLY

Please enter your comment!
Please enter your name here

This site uses Akismet to reduce spam. Learn how your comment data is processed.