Skip to content
Free Excel Tutorials
  • Home
  • Excel For Beginners
  • Excel Intermediate
  • Advanced Excel For Experts

Data Analysis

  • How to calculate current stock or inventory in Excel
  • Working With Tables in Excel
  • Filter Data Based on Date in Excel
  • Add Outline to Data in Excel
  • Move chart to a separate worksheet in Excel

References

  • How to get last row in text data in Excel
  • MATCH function: Description, Usage, Syntax, Examples and Explanation
  • Perform case-sensitive Lookup in Excel
  • Offset in Excel
  • How to use Excel OFFSET function

Data Validations

  • Excel Data validation no punctuation
  • Excel Data validation date in specific year
  • Excel Data validation number multiple 100
  • Excel Data validation unique values only
  • Data validation must not exist in list

How to create dynamic named range with INDEX in Excel

by

This tutorials show examples one and two dynamic named ranges created.

The first is created with the INDEX function together with the COUNTA function. Dynamic named ranges automatically expand and contract when data is added or removed.

Formula

=$A$1:INDEX($A:$A,lastrow)

Explanation

This page shows an example of a dynamic named range created with the INDEX function together with the COUNTA function. Dynamic named ranges automatically expand and contract when data is added or removed.

In the example shown, the named range “data” is defined by the following formula:

=$A$2:INDEX($A:$A,COUNTA($A:$A))

which resolves to the range $A$2:$A$10.

How this formulas works

Note first that this formula is composed in two parts that sit either side of the range operator (:). On the left, we have the starting reference for the range, hard-coded as:

$A$2

On the right is the ending reference for the range, created with INDEX like this:

INDEX($A:$A,COUNTA($A:$A))

Here, we feed INDEX all of column A for the array, then use COUNTA to figure out the “last row” in the range. COUNTA works well here because there are 10 values in column A, including a header row. COUNTA therefore returns 10, which goes directly into INDEX as the row number. INDEX then returns a reference to $A$10, the last used row in the range:

INDEX($A:$A,10) // resolves to $A$10

So, the final result of the formula is this range:

$A$2:$A$10

A two dimensional range

The above example works for a one-dimensional range. To create a two-dimensional dynamic range where the number of columns is also dynamic, you can use the same approach, expanded like this:

=$A$2:INDEX($1:$1048576,COUNTA($A:$A),COUNTA($1:$1))

As before, COUNTA is used to figure out the “lastrow”, and we use COUNTA again to get the “lastcolumn”. These are supplied to index as row_num and column_num respectively.

However, for the array, we supply the full worksheet, entered as all 1048576 rows, which allows INDEX to return a reference in a 2D space.

Note: Excel 2003 supports only 65535 rows.

Post navigation

Previous Post:

How to calculate project complete percentage in Excel

Next Post:

Popularly Used Excel Functions and their examples

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Learn Basic Excel

Ribbon
Workbook
Worksheets
Format Cells
Find & Select
Sort & Filter
Templates
Print
Share
Protect
Keyboard Shortcuts

Categories

  • Charts
  • Data Analysis
  • Data Validation
  • Excel Functions
    • Cube Functions
    • Database Functions
    • Date and Time Functions
    • Engineering Functions
    • Financial Functions
    • Information Functions
    • Logical Functions
    • Lookup and Reference Functions
    • Math and Trig Functions
    • Statistical Functions
    • Text Functions
    • Web Functions
  • Excel VBA
  • Excel Video Tutorials
  • Formatting
  • Grouping
  • Others

Logical Functions

  • OR function: Description, Usage, Syntax, Examples and Explanation
  • How to return blank in place of #DIV/0! error in Excel
  • NOT function: Description, Usage, Syntax, Examples and Explanation
  • IFERROR function: Description, Usage, Syntax, Examples and Explanation
  • How to use Excel TRUE Function

Date Time

  • Convert Excel time to decimal hours in Excel
  • Pad week numbers with zeros in Excel
  • Get work hours between dates in Excel
  • Calculate expiration date in Excel
  • Get month from date in Excel

Grouping

  • Map text to numbers in Excel
  • Map inputs to arbitrary values in Excel
  • Running count group by n size in Excel
  • Group numbers with VLOOKUP in Excel
  • How to randomly assign data to groups in Excel

General

  • Subtotal by color in Excel
  • How to generate random date between two dates in Excel
  • Check if multiple cells have same value in Excel
  • How to add sequential row numbers to a set of data in Excel
  • Lock Cells in a Worksheet Excel
© 2025 xlsoffice . All Right Reserved. | Teal Smiles | Abbreviations And Their Meaning