Written by Allen Wyatt (last updated June 4, 2022)
This tip applies to Excel 2007, 2010, 2013, 2016, 2019, 2021, and Excel in Microsoft 365
Libby wants to insert a row number into column A of her worksheet. She wants the column to reflect the correct number of the row, even when she adds or deletes rows.
The need that Libby has expressed precludes using any static numbering scheme in column A. Since she wants the row numbers to update automatically if she adds or deletes rows, then a formula is needed. There are any number of formulas you can use in column A that will return a row number. Perhaps the easiest is to use the ROW function, like this:
=ROW()
This formula returns the row number of the cell in which the formula appears. If you want to offset the row number returned (for instance, if you have some headers in rows 1 and 2 and you want cell A3 to return a row value of 1), then you can modify the formula to reflect the desired adjustment:
=ROW()-2
Of course, the ROW function isn't the only candidate for your formulas. You can also use a formula that actually examines the contents of the adjacent column (B) and return a row number only if there is something in that adjacent cell.
=IF(TRIM(B1)<>"",COUNTA($B$1:B1)&".","")
This formula, placed in cell A1, examines the contents of cell B1. If there is something there, then the COUNTA function is used to count the number of occupied cells between cell B1 and whatever cell is to the right of where this formula is placed. The formula also places a period after the row number that is returned. Make sure the dollar signs are included, as shown, and then copy the formula down as many cells as necessary to create your row numbers.
The advantage to a formula such as this one is that it checks to see if something is in column B before it returns a row number. This means that you can copy the formula down beyond the actual end of your data rows, and only those rows that have data (triggered by something in column B) will have a row number. The same sort of technique could be used with the ROW function instead of the COUNTA function:
=IF(TRIM(B1)<>"",ROW()&".","")
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (10104) applies to Microsoft Excel 2007, 2010, 2013, 2016, 2019, 2021, and Excel in Microsoft 365. You can find a version of this tip for the older menu interface of Excel here: Automatically Numbering Rows.
Professional Development Guidance! Four world-class developers offer start-to-finish guidance for building powerful, robust, and secure applications with Excel. The authors show how to consistently make the right design decisions and make the most of Excel's powerful features. Check out Professional Excel Development today!
When Excel performs a calculation, the results you see in an unformatted cell may cause a bit of concern. This tip ...
Discover MoreWhen working with arrays in a formula, it can be a bit confusing to understand how they work. In this tip I examine a ...
Discover MoreFinding the maximum value in a range of cells is easy; finding the address of the cell containing that value is a ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
2023-03-11 05:10:47
Barry
Putting your data into an Excel Table will automatically copy formulas down whenever a new row is added.
2023-03-10 10:52:04
Ron S
Here is another article that gives you formulas for several situations
https://exceljet.net/formulas/automatic-row-numbers
While you are there check out his "500 Formulas" link.
Got a version of Excel that uses the ribbon interface (Excel 2007 or later)? This site is for you! If you use an earlier version of Excel, visit our ExcelTips site focusing on the menu interface.
FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
Copyright © 2025 Sharon Parq Associates, Inc.
Comments