Excel INDIRECT Function: Formulas and Examples (2024)
Some functions of Excel are simply meant to amaze you. The INDIRECT function is also one of that lot π
Technically speaking, it will not perform any operation, nor will it run any logical tests to return Boolean Values. It is a unique function thatβs different from all other functions of Excel.
If you have had too much suspense already, let’s just dive right into the guide below. What is the INDIRECT function, how is it used and what is it used for β we will answer that all in there. π
As you continue reading, do not forget to download our free sample workbook thatβll help you tag along with the guide.
Table of Contents
How to use the INDIRECT function
The INDIRECT crates an indirect reference to cells, ranges, sheets, and workbooks, too π
Hard to get until we see an example of how it is applied, so here we go.
The image here has some value in Cell A2.
data:image/s3,"s3://crabby-images/ade94/ade9400d54b0aaef813868d2a6256887459dbb00" alt="01 cell a2 Cell Address A2"
- Write A2 in another cell (Cell B2).
Make sure you don’t write it as =A2, or else Excel will create a link to Cell A2 in Cell B2. Right now, we are only writing A2 as a simple text β
- In another cell, write the INDIRECT function as follows:
= INDIRECT (B2)
data:image/s3,"s3://crabby-images/dc36c/dc36c3251ee85d9226c43630d131d9ab25b2f8bc" alt="02 write indirect Writing the INDIRECT function"
We have created a reference to Cell B2 (that contains the text string A2).
- Hit Enter.
data:image/s3,"s3://crabby-images/3a224/3a2249dd4d8aea2df89824b001b47add2ada2365" alt="03 enter indirect The INDIRECT formula refers to Cell A1"
Magic π₯ Whatβs that?
The Excel INDIRECT function returns the value of Cell A2.
From the backstage view, the INDIRECT function turned the text string in Cell B2 (A2) into a cell range and created an indirect reference to it.
So what if our data was not just a single cell but a column long like here π
data:image/s3,"s3://crabby-images/f2c89/f2c8965e6b87489b2277c85d989a7fef31a2e337" alt="04 data list A column-long logical value data"
Not a problem!
- In Cell B2, write the cell range A2:A5.
data:image/s3,"s3://crabby-images/03be6/03be69ed7dc9f802db99be146ad8dc075ce138e7" alt="05 cell range The cell range A2:A5"
- Again write the INDIRECT function just like above.
= INDIRECT (B2)
data:image/s3,"s3://crabby-images/db5ca/db5cabbf388100545fbf9a024159061e89804c7f" alt="06 write indirect Excel INDIRECT function syntax"
- Hit Enter.
data:image/s3,"s3://crabby-images/81ee2/81ee2bd9066d856e19141b1832e7aadfb302d898" alt="07 enter indirect The INDIRECT function returns the result"
This time the INDIRECT function treats the text string A2:A5 as a range and returns the whole of it π
Pro Tip!
Whenever you delete, add, or move cells in Excel, it automatically updates the cell references in formulas.
The INDIRECT function doesnβt do that. For example, if you add a row before Column A in the example above, the column containing the data will move ahead and become Column B.
The INDIRECT function will not update the results and return the same cell range A2:A5 π
data:image/s3,"s3://crabby-images/f98dd/f98dd73be2c9b8d1b56bc2c0dfcd87ebe19972d1" alt="08 update results The INDIRECT function doesnβt update results"
But how does it make sense to use it practically? We will see that in the examples below π‘
Other INDIRECT formula examples
We are on our way to more interesting examples of the INDIRECT function β you are sitting in tight, right?
Reference to other sheets (with and without CONCATENATE)
Using the INDIRECT function, you can not only create indirect references to other cells from the same sheet but to other sheets too.
For example, here is Sheet 2 of an Excel workbook. Where Cell A1 contains a value π
data:image/s3,"s3://crabby-images/43e86/43e86e23af0945f48354c8f0068c935b8724160d" alt="09 cell value worksheet no.2 of a workbook"
Pro Tip:
Note that when we create a reference to cells from other sheets, the reference looks like the below:
Sheet Name + Exclamation Mark (!) + Cell Reference
So, if we create a reference to Cell A1 from Sheet 2, it will look like this:
Sheet2!A1
data:image/s3,"s3://crabby-images/f547a/f547a0d21de60b5a0fa538da1786685c6b1d6b41" alt="10 create ref Reference to another sheet"
We are now in Sheet 1 of the same workbook. To create an indirect reference to Cell A1 from Sheet2:
- Activate a cell (Cell A2) and write the sheet reference below:
Sheet2!A1
data:image/s3,"s3://crabby-images/c773b/c773b222a3e47b71fa0288691bc0220638b1b81f" alt="11 activate cell Writing the sheet reference"
- In another cell, write the INDIRECT function as follows:
= INDIRECT (A2)
data:image/s3,"s3://crabby-images/fa5f9/fa5f959559a6cc92160e83127c732f4c558db4b2" alt="12 write indirect Writing the INDIRECT function"
- Hit Enter and you have your indirect reference to another sheet all set β
data:image/s3,"s3://crabby-images/18400/18400f66fe265d076de0ddecf5b9a30c961c8c2d" alt="13 enter indirect Reference to another sheet"
We have the value from cell A1 of Sheet 2 in Sheet 1. Yay!
If you find it hard to write the cell reference from another sheet like that, you may use the CONCATENATE function as below:
- Write the name of the sheet and cell reference in different cells. And merge them with an exclamation mark in between to get the sheet reference like below.
= CONCATENATE (A2,β!β, B2)
data:image/s3,"s3://crabby-images/623b0/623b0aafaa551f575dee0e58a625ee642593f01a" alt="14 write sheet The Sheet reference"
Must not forget to enclose the exclamation mark in double quotation marks π―
- Wrap the above function in the INDIRECT function.
= INDIRECT (CONCATENATE (A2,β!β, B2))
data:image/s3,"s3://crabby-images/75a49/75a49005dd1cb835d13b34ca5b6f9651e0684378" alt="15 wrap indirect INDIRECT and CONCATENATE"
- Hit Enter to reach the same results again.
data:image/s3,"s3://crabby-images/2ec3b/2ec3b560cde0d395022d379d16c2bac7e5b23891" alt="16 enter indirect Reference to Sheet 2"
Fun, isnβt it π
Performing functions on Named Ranges
The INDIRECT function can not only recognize cell references and ranges but named ranges too. See for yourself.
Here is a list of some expenses (yeah, many of them) π°
data:image/s3,"s3://crabby-images/ca6ad/ca6ad1786d47d736895c8af3f18eb36175cfaaa5" alt="17 expenses list List of expenses"
Turn them into a named range by following these steps:
- Select the list of expenses (the numbers only).
data:image/s3,"s3://crabby-images/b5d13/b5d137c16a4e958e5d31b4cd0a9d888529c2f1e0" alt="18 item list Selection of column"
- Go to the Formulas tab > Name Manager.
data:image/s3,"s3://crabby-images/ba225/ba22524028c53953a0345306fa61e68d19197622" alt="19 name manager The Name manager"
- From the Name Manager dialog box, select New.
data:image/s3,"s3://crabby-images/28a86/28a864a90006d7a46167eeaa790847510fc26efd" alt="20 new name Setting a new named range"
- Set a name for the defined range (we are setting it to Expenses).
data:image/s3,"s3://crabby-images/60e91/60e9182ab959dbdbdbbc2b3677f443286a5a86c2" alt="21 name expenses Setting the name to Expenses"
- Click Okay.
The range is saved by the name Expenses π―
data:image/s3,"s3://crabby-images/c0660/c06603ff0a0fefd42d818b5fdc13dfd4881aafed" alt="22 range saved Range saved"
- Close the Name Manager.
- Activate any cell (Cell D2) and write the name of the range (Expenses) in it. Make sure not to make any spelling mistakes.
data:image/s3,"s3://crabby-images/921e6/921e62428268a75939956d7be9a8fdffdb3a3ff0" alt="23 cell d2 Writing the name of the range"
- In another cell write the INDIRECT function as follows:
= INDIRECT (D2)
data:image/s3,"s3://crabby-images/966f9/966f91c9b100dc363e78480e19e3cf729fb570b6" alt="24 write indirect Writing the name of the range"
- Hit Enter to see that the INDIRECT function will return the whole range that you saved by the name Expenses πββοΈ
data:image/s3,"s3://crabby-images/0bac6/0bac60d32f784d4b4ff2dbabbeae817640cf7fd8" alt="25 whole range The whole range returned"
Cool! But we will take it a step ahead.
- Now wrap the INDIRECT function in the SUM function as below:
= SUM (INDIRECT (D2))
data:image/s3,"s3://crabby-images/4a278/4a2784c9f0e50f5272d5036caac5f372e8738830" alt="26 sum indirect Wrapping the INDIRECT function in the SUM function"
- Hit Enter.
data:image/s3,"s3://crabby-images/ddf62/ddf62c2c3fdcb45cfa77ee7469cb78f705e39f5e" alt="27 enter sum The SUM of the range"
Viola! We have the sum of the range Expenses. Thatβs how you can use the INDIRECT function to create an indirect reference to ranges πͺ
You may try any function with that. For example, wrap the INDIRECT function above in the AVERAGE function to get the average of the said range.
= AVERAGE (INDIRECT (D2))
data:image/s3,"s3://crabby-images/a5572/a5572edd4c23ab41eea13f5bfb9554810bfefce2" alt="28 ave indirect Average of the range"
Pro Tip!
Named ranges are not like cell references.
Even if you add, move or delete cells before or after a named range (Expenses), the answer to the INDIRECT function won’t change. See that below π΄ββοΈ
- Add a column behind Column A as below
data:image/s3,"s3://crabby-images/e16c7/e16c7766767fe48d60b68439081017b829b8a40a" alt="29 add column Adding a column behind Column A for data validation"
- The answer to the INDIRECT function remains unchanged. That’s because the range of Expenses remains unchanged π
data:image/s3,"s3://crabby-images/10a40/10a40bc8225e80d44f710ffef8ba6899844d7c20" alt="30 unchanged answer Answer remains unchanged"
That’s it – Now what?
Through the above guide, we have learned the primary use and operation of the INDIRECT function in Excel.
Not to forget, we have also seen multiple examples of you can bring it to use practically. Hope you enjoyed learning about it π§
Because if you did, your learning journey has yet only begun. There are so many more functions in the Excel library that you must explore.
To begin with, I suggest you learn about the VLOOKUP, SUMIF, and IF functions (my top favorite Excel functions).
Other resources
The INDIRECT function can only create an indirect reference to another cell. But how do you create a direct reference in Excel?
There are three kinds of direct references that you can create in Excel – learn about them all here.