How to Randomly Select N Numbers in Google Sheets

This tutorial covers an efficient solution to randomly select N numbers or values in Google Sheets. The key functions used are SORTN, UNIQUE, and RANDARRAY. If the list contains duplicates, the formula will automatically select only the unique values.

Real-Life Applications

Here are some scenarios where this formula can be applied:

  • Selecting a random group of players.
  • Choosing N winners in a lottery.
  • Excluding excess participants randomly when you have a limited quota.

Formula to Randomly Select N Numbers

=LET(
  range, TOCOL(UNIQUE(cell_range), 3), 
  SORTN(range, n, 0, RANDARRAY(ROWS(range)), 1)
)

In this formula:

  • Replace cell_range with the column reference containing the values you want to randomly select.
  • Replace n with the number of random values you want to pick. If the cell_range contains fewer numbers than the value specified in n, the list will be returned as is, but without duplicates.

This formula works for randomly selecting numbers, text, or any other data types.

Example: Randomly Selecting N Values

Suppose you have lottery serial numbers in the range A2:A and want to randomly pick 10 numbers without duplicates. Use the formula:

=LET(
   range, TOCOL(UNIQUE(A2:A), 3), 
   SORTN(range, 10, 0, RANDARRAY(ROWS(range)), 1)
)
Randomly select 10 unique numbers from a list in column A

Lottery numbers often include alphanumeric characters, such as AX-125467B. Since the formula works with any data type, it will efficiently pick N winners, regardless of whether the values are numeric or text.

Anatomy of the Formula

This formula has several components. Let’s break it down step-by-step. The LET function is used to simplify the formula by assigning names to intermediate results. Its syntax is:

LET(name1, value_expression1, [name2, value_expression2, …], formula_expression)

In the Formula:

  • name1: range
  • value_expression1: TOCOL(UNIQUE(A2:A), 3)

What Does value_expression1 Do?

  • UNIQUE(A2:A): Extracts distinct values from the range. If the range contains empty cells, an empty string will appear in the result.
  • TOCOL(..., 3): Converts the column into a single array while removing empty and error values.

This intermediate result (range) is then used in the next part of the formula.

The formula_expression Explained:

SORTN(range, 10, 0, RANDARRAY(ROWS(range)), 1)

Here’s how this works:

  • SORTN: Selects and sorts the top N rows.
  • range: The array of unique values generated earlier.
  • n: 10, the number of random values to return.
  • display_ties_mode: 0, ensures only the first 10 rows are returned.
  • sort_column: RANDARRAY(ROWS(range)), generates random numbers for sorting.
  • is_ascending: 1, sorts the random numbers in ascending order.

This ensures that 10 random values are selected and sorted.

Prevent the Formula from Changing on Every Update

By default, RANDARRAY is volatile, meaning the results refresh every time you edit the sheet or at specific intervals set under File > Settings. If you want the formula to remain static until triggered, you can use the LAMBDA function.

Steps:

  1. Insert a tick box in an empty cell (e.g., B2) via Insert > Tick Box.
  2. Use this modified formula in C2:
=IF(
   B2=FALSE, ,
   LAMBDA(
      randN, SORTN(TOCOL(UNIQUE(A2:A), 3), 10, 0, randN, 1)
   ) (RANDARRAY(ROWS(TOCOL(UNIQUE(A2:A), 3))))
)
Randomly select unique n numbers with static results

Explanation:

  • When B2 is unchecked (FALSE), the formula returns an empty string.
  • When checked, it randomly selects N numbers/values.
  • randN: A name assigned to RANDARRAY(ROWS(TOCOL(UNIQUE(A2:A), 3))) within the LAMBDA function.
  • LAMBDA Syntax:
=LAMBDA([name, ...], formula_expression)(function_call, ...)

Here:

  • name: randN
  • formula_expression: SORTN(TOCOL(UNIQUE(A2:A), 3), 10, 0, randN, 1)
  • function_call: RANDARRAY(ROWS(TOCOL(UNIQUE(A2:A), 3)))

This approach prevents the formula from recalculating unless you toggle the tick box.

Additional 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...

6 COMMENTS

  1. Excellent article and explanation, thank you very much! But the formula came back #Error in my Spreadsheets. Do you help me with any solution?

  2. Hi Prashanth! Thank you so much for this equation. I’m about 95% through my project, thanks to this. I have a question, though.

    Are you able to insert a FILTER function into this equation? Say, for instance, I had a large data set to apply your equation to, but only wanted to pull random numbers that met certain conditions:

    So, instead of your fixed range, (A1:A20), let’s say I wanted to do something like FILTER(A2:A,A2:A$D3) . . . where D=100;

    FILTER(A2:A,A2:A>$D4) . . . where D=500, etc.

    So I was hoping the filter function could be integrated into your master formula:

    Any suggestions?

    Thanks in advance!

      • Hi, Stephen,

        For this, I am going to provide you a different formula. If that doesn’t help, please share an example sheet with me in reply.

        Google Sheets has now a more convenient formula to generate random numbers in an array form and that is RANDARRAY. I am going to use that here in SORTN.

        =SORTN(FILTER(A1:A,A1:A>D3),9^9,0,randarray(COUNTA(FILTER(A1:A,A1:A>D3)),1),TRUE)

        How to use this formula?

        This filters the numbers in column A based on the value in cell D3 and randomizes the filtered output.

        The 9^9 in the formula is to return all the filtered values in random order. You can change that to any number to limit the number of rows in the output. If you set it to 10, you will get 10 random numbers. But if the filtered output doesn’t contain 10 numbers, the formula would return an error.

        To understand the formula please check the individual tutorials related to SORTN and RANDARRAY. I’ll try to write a tutorial on the combined use later.

        Best,

        Prashanth KV

  3. Hi Prashanth, fantastic article and great explanation, thanks so much! It really helped me with my research.

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.