Group-Wise Serial Numbering in Google Sheets

A standard table usually starts with a serial number column. If your table has such a column, you can easily generate continuous numbers using the ROW function. But how do you populate group-wise serial numbers?

By “group-wise serial numbering,” I mean that the serial number should restart from 1 whenever a new group begins. In this tutorial, you’ll learn how to achieve this technique in Google Sheets.

Formula:

=SCAN(0, range, LAMBDA(a, v, IF(v="",,IF(v=OFFSET(v, IF(ROW(v)=1, 1,-1),),a+COUNTA(v), 1))))

When using this formula, replace range with the cell range that contains your category data.

For example, if your category data is in the range B1:B, replace range with B1:B and apply the formula starting in the first row of an empty column (e.g., cell A1).

Example of Group-Wise Serial Numbering in Google Sheets

Consider the following example, where Column A contains the categories, and we want to generate the group-wise serial numbers in Column B:

Group-wise serial numbering in Google Sheets using the SCAN function

In this example, the range A1:A contains the categories, and the category field label is in cell A1. The category data starts from cell A2.

The following formula in cell B2 will generate group-wise serial numbers in Column B:

=SCAN(0, A2:A, LAMBDA(a, v, IF(v="",,IF(v=OFFSET(v, IF(ROW(v)=1, 1,-1),),a+COUNTA(v), 1))))

Formula Breakdown:

This formula uses the SCAN function along with a LAMBDA helper function. Here’s how it works:

SCAN(initial_value, array_or_range, lambda)
  • initial_value: This is set to 0 in the formula.
  • array_or_range: This is the range A2:A (where the categories are located).
  • lambda: This function processes each element in the range.

Within the LAMBDA function:

LAMBDA(a, v, IF(v="",,IF(v=OFFSET(v, IF(ROW(v)=1, 1,-1),),a+COUNTA(v), 1)))
  • a stores the intermediate values of the SCAN operation, starting at 0.
  • v represents each value in the array (A2:A).

The formula does the following:

  1. IF(v="", , ...): Checks if the current value is empty. If it’s empty, the formula returns an empty result. If it’s not empty, it proceeds to the next step.
  2. IF(v=OFFSET(v, IF(ROW(v)=1, 1, -1),), ...): Compares the current value v with the value in the previous row (using OFFSET). The logic here is as follows:
    • If v is equal to the value in the previous row, it adds the count of occurrences of v to the accumulator a (which is the serial number).
    • If the value is different from the previous row, it resets the serial number to 1.
      This ensures that whenever the category changes (e.g., from “Admin” to “Sales”), the serial number restarts from 1.
  3. a+COUNTA(v): Adds the count of occurrences of the current category v to the accumulator a (essentially counting each row in the same category).
  4. 1: If the value does not match the previous row’s value, it resets the serial number to 1 for the new group.

How Group-Wise Serial Numbering Differs from Running Count

The key difference between this formula and a running count is how the serial number behaves when the category changes.

  • Group-Wise Serial Numbering: The serial number resets to 1 whenever a new group starts. If the same category (e.g., “Admin”) appears later in the column after a different group, it is treated as a new group, and the serial number starts from 1 again.
  • Running Count: A running count continues without resetting, treating all occurrences of the same category as part of the same group. When used with sorted data, it will behave like group-wise serial numbering, as the sorted order groups similar values together.

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

5 COMMENTS

  1. Hi Prashanth,

    I’ve been trying to figure out how to do this for the longest time. I never considered combining match & row. This is fantastic.

    Thank you so much!
    Dan

    • Hi, Bajran,

      You should format the numbers as below.

      1. Select the range/array containing the numbers.
      2. Click the menu Format > Number > More formats > Custum number format.
      3. Enter 00 in the blank field.

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.