SMALL Function Basics & Advanced Applications in Google Sheets

Published on

Today, I’ll show you how to use the SMALL function for both basic and advanced calculations in Google Sheets. This function finds the nth smallest element in a list you choose.

At first glance, the Google Sheets SMALL function seems simple. However, it can assist with lookup or offset operations by finding the nth occurrence. To achieve this, we will use a logical test with the IF and SEQUENCE functions.

We’ll explore this advanced tip after covering the syntax and basic formula examples of the SMALL function.

SMALL Function Syntax and Arguments

Syntax:

SMALL(data, n)

Arguments:

The SMALL function has two arguments:

  • data: This is the array or range that contains the dataset you want to evaluate.
  • n: This specifies the rank, from smallest to largest, of the element you want to retrieve.

Basic Formula Examples

In a sequence from 1 to 10, setting ‘n’ to 3 will return 3, as it is the third smallest value in the dataset.

For example, use this formula to find the 3rd smallest value in column B:

=SMALL(B:B, 3)

The SMALL formula returns a #NUM! error when:

  • The range contains fewer than ‘n’ numbers
  • The range is empty
  • The range contains only text values.

What happens with multiple occurrences of numbers in the ‘data’ used with SMALL?

To understand this, try the following formula in your sheet. It will return 2 as the third smallest value in the provided array.

=SMALL({1, 2, 2, 3}, 3)

You can specify multiple ‘n’ values within the SMALL function as an array. When doing so, remember to use the ARRAYFORMULA function. Here’s an example:

=ArrayFormula(SUM(SMALL(B1:B10, {1, 2, 3})))

This formula calculates the sum of the first, second, and third smallest values in the range B1:B10.

SMALL Function to Locate the Nth Occurrence of a Text in Google Sheets

For example, in a sheet, I have fruit names in the range A2:A, such as Apple, Mango, Orange, etc. Some of the fruit names appear multiple times.

I want to find the relative position of the second occurrence of the item Mango. How do we find it?

Apple
Mango
Orange
Mango
Strawberry
Grape
Mango
Blueberry
Pineapple
Watermelon
Cherry
Pineapple
Pineapple

There are many methods. Here is one approach using the SMALL function in combination with IF and SEQUENCE.

The following formula will return 4, which is the relative position of the second occurrence of Mango in the range A2:A.

=ArrayFormula(SMALL(IF(A2:A="Mango", SEQUENCE(ROWS(A2:A)),), 2))

You can use this function in combination with the INDEX function to offset that many rows in another column and get the corresponding value. First, we will see the explanation of the above formula.

Formula Breakdown

  • SEQUENCE(ROWS(A2:A)): Returns a sequence of numbers from 1 to the number of rows in the range A2:A.
  • IF(A2:A="Mango", …, ): Returns an empty sequence number wherever A2:A doesn’t contain the fruit name Mango.
    SMALL function to find the relative position of the nth occurrence of a text
  • SMALL(…, 2) – Returns the second smallest value in the above data.

SMALL With INDEX to OFFSET Rows

Now let’s see how to use the relative position to offset rows in B2:B using the INDEX function.

Syntax:

INDEX(reference, [row], [column])

Formula:

=INDEX(B2:B, SMALL(IF(A2:A="Mango", SEQUENCE(ROWS(A2:A)),), 2))

Where:

  • reference: B2:B
  • row: SMALL(IF(A2:A="Mango", SEQUENCE(ROWS(A2:A)),), 2)

Note: I’ve omitted ARRAYFORMULA within INDEX as it’s not necessary here.

This INDEX and SMALL combo formula will return the value in B2:B corresponding to the 4th row in the range, which matches the second occurrence of “Mango” in column A.

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.

Hierarchical Numbering Sequences in Excel

Creating hierarchical numbering sequences in an Excel spreadsheet can significantly improve the way you...

How to Easily Repeat a Sequence of Numbers in Excel

Excel offers multiple ways to accomplish tasks, and the simplicity of each approach depends...

Create a Sequence of Dates at Every Nth Row in Excel (Dynamic Array)

Would you like to create a sequence of dates in every nth row in...

XMATCH Row by Row: Finding Values Across a Range in Google Sheets

Using the BYROW function with XMATCH in Google Sheets allows us to match values...

More like this

XMATCH Row by Row: Finding Values Across a Range in Google Sheets

Using the BYROW function with XMATCH in Google Sheets allows us to match values...

Limit Formula Expansion to a Specific Row in Google Sheets

In this tutorial, I’ll explain how to limit the expansion of an array formula...

3-D Referencing Structured Data Tables in Google Sheets

When you have several tables within a single sheet—not across multiple sheets in a...

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.