Please Note: This article is written for users of the following Microsoft Excel versions: 97, 2000, 2002, and 2003. If you are using a later version (Excel 2007 or later), this tip may not work for you. For a version of this tip written specifically for later versions of Excel, click here: Referencing the Last Cell in a Column.

# Referencing the Last Cell in a Column

by Allen Wyatt
(last updated July 24, 2014)

Patty asked about a common scenario, in which column B contains quite a bit of data, and information can be added to the cells in the column at any time. In a formula in cell C4, Patty wants to see the value at the bottom of those cells in column B that contain values. Thus, if cells B1:B27 contain data, then in cell C4 Patty wants to see the value that is in cell B27. If three more pieces of data are added to column B, then the value in C4 should contain the value in B30.

The solution to this problem depends on whether you can count on the data in column B containing blank cells or not. If the data is contiguous—it doesn't contain any blank cells—then you can use the following formula in C4:

```=INDIRECT("B"&COUNTA(B:B))
```

This constructs an address based on the last cell in the column, and then uses the INDIRECT function to return the value at that address.

If it is possible for there to be blanks in column B, then the following formula will work:

```=INDIRECT("B"&MAX(ROW(1:65535)*(B1:B65535<>"")))
```

Again, the INDIRECT function is used to fetch the actual value, but the address used by INDIRECT is put together differently.

A different approach is to use the VLOOKUP function to return the value. If column B consists of numeric values, then the following formula in C4 will work just fine:

```=VLOOKUP(9.99999999999999E+307,B:B,1)
```

If column B contains text, then the numeric lookup won't work, but the following will:

```=VLOOKUP(REPT("z",50),B:B,1)
```

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2103) applies to Microsoft Excel 97, 2000, 2002, and 2003. You can find a version of this tip for the ribbon interface of Excel (Excel 2007 and later) here: Referencing the Last Cell in a Column.

##### Author Bio

Allen Wyatt

With more than 50 non-fiction books and numerous magazine articles to his credit, Allen Wyatt is an internationally recognized author. He  is president of Sharon Parq Associates, a computer and publishing services company. ...

##### MORE FROM ALLEN

Can't Merge Alphanumeric Data Correctly

When you merge data from Excel into a Word document, you may need to do some conditional processing based on the data you are ...

Discover More

No Ribbon on New Documents

The way that you work with commands in Word is primarily through the ribbon. What do you do if the ribbon disappears when you ...

Discover More

The mail merge tool available in Word is powerful, allowing you to use data from a variety of sources to create hundreds or ...

Discover More

Program Successfully in Excel! John Walkenbach's name is synonymous with excellence in deciphering complex technical topics. With this comprehensive guide, "Mr. Spreadsheet" shows how to maximize your Excel experience using professional spreadsheet application development tips from his own personal bookshelf. Check out Excel 2013 Power Programming with VBA today!

Shortcut for Selecting a Data Range

Want to select all the data in a contiguous section of a worksheet? The shortcut discussed in this tip makes it very easy.

Discover More

Combining Multiple Rows in a Column

Do you need to concatenate the contents of a range of cells in the same column? Here's a formula and a handy macro to make ...

Discover More

Checking for an Entry in a Cell

You may be looking for a way to have a formula determine if a particular cell has anything in it. Here's how you can find the ...

Discover More
##### Subscribe

FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."

If you would like to add an image to your comment (not an avatar, but an image to help in making the point of your comment), include the characters [{fig}] in your comment text. You’ll be prompted to upload your image when you submit the comment. Maximum image size is 6Mpixels. Images larger than 600px wide or 1000px tall will be reduced. Up to three images may be included in a comment. All images are subject to review. Commenting privileges may be curtailed if inappropriate images are posted.

What is eight more than 2?

2016-10-02 14:48:32

Barry

The last cell I'm trying to reference contains a formula which is returning the value. I've tried each formula you suggest and nothing works. Any suggestions?

2016-09-15 11:04:44

Bathinda Helper

If you want to move the last empty cell of the current column (not worksheet's last, but last cell of the current region you're working on), You can use Asap utilities also to move to the last cell of the current column (last cell of your data region, not of the worksheet), even if the same is filled or empty.

Very good piece of software and FREE too.

2016-08-12 09:59:52

Burhanuddin

=VLOOKUP(9.99999999999999E+307,B:B,1)
How this formula works

2016-06-07 05:51:04

Michael (Micky) Avidan

@Bridget,
Try: =VLOOKUP(9^9,A:A,1)
--------------------------
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2016)
ISRAEL

2016-06-06 16:40:13

Bridget

The vlookup formula worked, but I need to take it one step further.... In Column A is a date for every day of the calendar year. Column B is a number value. The vlookup helped me obtain the last value in column B, but I need to get the corresponding date in column A for the last value. (I need the date in column A, not the value in column B.) Can anyone help with this?

2016-03-28 08:59:39

Steve

No, it didn't have the word "Available" in it or anywhere in the spreadsheet for that matter. I did enter it using Ctrl-Shift-Enter.

2016-01-05 05:29:39

Barry

@Steve,

The formula using the MAX(ROW(1:65535)*(B1:B65535<>"") to find the row number of the last cell is an "array" formula and must be entered into the cell using Crtl+Shift+Enter (rather than just pressing Enter). Also if you edit the formula you must re-enter the formula in the cell using Crtl+Shift+Enter otherwise Excel will treat it as a standard formula and give an incorrect result or an error message.

The reason for this is the element of the formula B1:B65535 defines a range of cells with the first cell (B1) being deemed as the activecell for that range, the value of which will be returned in a standard formula (which is why the word "Available" is being returned in your case). In an array formula all values in the defined range are returned.

The formula using COUNTA(B:B) to find the row number of the last cell is just a standard formula, and can be entered in the usual way.

If you do not use the Crtl+Shift+Enter with the first formula then you will just get the value in cell B1 (or D1 if you've changed the references to "D" from "B") which I guess has the word "Available" in it.

2016-01-04 07:06:46

Steve

Can you please provide insight on my first question, posted 29 Dec 2015, 07:13?

2016-01-01 05:45:45

Barry

@Steve,

As I said just drop the INDIRECT function.

The formula then becomes ="B" & MAX(ROW(1:65535)*(B1:B65535<>"")) or if you want an absolute address use:
="\$B\$" & MAX(ROW(1:65535)*(B1:B65535<>""))

NB remember this is an array formula and therefore needs the Crtl+Shift+Enter combination to enter it.

2015-12-31 08:58:53

Steve

Thanks, Barry. I tried all kinds of formulas to return the address, for use in another formula, all without success. Each attempt worked fine, but only when the formula was in a cell by itself. When I tried to use it inside another formula, well, nothing.

But so much for that. Can you provide any insight on my first question, posted 29 Dec 2015, 07:13?

2015-12-30 06:03:00

Barry

@Steve

Just drop the INDIRECT function.

NOTE: the formulas using the MAX function are "array" formulas and should be entered using the 'Ctril+Shift+Enter" key combination for it to work.

2015-12-29 07:14:35

Steve

What if i want to return the address, not the value, of the last cell?

2015-12-29 07:13:31

Steve

I entered =INDIRECT("B"&MAX(ROW(1:65535)*(B1:B65535<>"")))

then changed the three "B" to "D"

The last cell was D62 and everything above had entries, but the formula returned the word "Available" - I don't understand why. Using =INDIRECT("B"&COUNTA(B:B)) correctly returned the value 10.

2015-11-14 09:22:46

Michael (Micky) Avidan

@Kirk,
Check out the linked picture if it is for any help for you.

http://screenpresso.com/=mK4Nc

--------------------------
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2016)
ISRAEL

2015-11-13 18:45:11

Kirk

Need a formula to return the value of a cell that begins with specific text "Report Parameters".

I paste raw data to a sheet and "Column A" always has one row near the bottom that starts with "Report Parameters". I want the text of that cell to show in another palce in my template. The problem is that depending the report, that text gets pasted to different rows, but always in Column A.

2015-09-04 10:02:47

Michael (Micky) Avidan

@faizul,
Everything should work fine if you will follow the exact procedure.
Take a look at the example in the uploaded picture: http://screenpresso.com/=QUdW
---------------------------------------
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2016)
ISRAEL

2015-08-31 07:26:58

faizul

hello there.

Thank you for your brilliant tips.
For advancing your formula on vlookup, could you suggest on referencing to second last and third last row and so forth?

2015-07-08 05:09:33

Carl Willems

I was looking for a way to see the last cell in a column of a Table (Listobject), so it would always show the latest version of the workbook in the input sheet. Since the top cell wasn't row 1 and there was data above the column, COUNT(A:A) couldn't work. I came up with =OFFSET(tbVersions[[#Headers],[Version]],COUNTA(tbVersions[[#All],[Version]])-1,0)
Just wanted to share, may be helpful to others.

2015-06-16 22:42:44

sivakumar

i am struggling from few days how to reference the last cell value in a dynamic column.
thank you Allen Wyatt
now i am really happy

2015-05-18 11:51:14

Michael (Micky) Avidan

@ChauKTV,
My suggestion applies to an ALPHANUMERIC string which means a "TEXTUAL" value.
Whwt are you looking for ?
* The last cell's address or the Last cell's value ?
What are the value types in your column "A" ?
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-201)
ISRAEL

2015-05-18 02:03:48

ChauKTV

i try:
=MATCH("*",\$A:\$A,-1) and

=MAX(MATCH(9^15,A:A),MATCH(CHAR(255),A:A,1))

Excel show wrong, please make 1 example for me please, Michael (Micky) Avidan.

Tks.

2015-04-26 15:30:39

Ihsaan

Thanks this really helped me. I used the VLOOKUP method. Any idea how I would find the second last cell as opposed to finding the last cell?

2015-04-15 17:42:33

dan

@anand what you want is called an absolute reference... generally you use the cell designation with a "\$" so you wanted B5, you would write your formula
B7=A7/\$B\$5 when you copy it, the \$b\$5 reference will stay the same.

2015-04-05 06:30:49

Michael (Micky) Avidan

@Anand,
In cell B7 type:
=A7*B\$5
and copy down along column "B".
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2015)
ISRAEL

2015-04-04 09:21:31

ANAND

I HAVE A QUERRY

SAY I HAVE A NO IN B5

AND NUMERIC VALUES IN A7,A8,A9,.....,A101 AND CONTINUE..

IF I WANT THE VALUES IN B7,B8,B9,......

AS

B7=A7/B5
B8=A8/B5
B9=A9/B5 AND SO ON.

WHAT SHOULD I DO.

2015-01-09 05:38:39

Michael (Micky) Avidan

@Lars,
Your request doesn't come close to Blaine's request.
As far as I recall - you need to have the target file OPEN in order to write to it.
It is usually done with VBA Programming and the target workbook doesn't have to be visible.
The vba code opens it > writes into > closes.
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2015)
ISRAEL

2015-01-09 04:29:31

Lars

I have a very similar, if not the same, question as Blaine.

How do I write a value to next empty cell in a column in a workbook that is not opened ?

2014-12-11 06:17:41

Michael (Micky) Avidan

@Abe,
The principal is shown in the linked picture:
http://postimg.org/image/rh66txmrj/
Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2015)
ISRAEL

2014-12-10 14:54:15

Abe

Hi, im trying to get the avergae of the last three cells of a data set. they get updated on a monthly basis so i don't want to keep moving the formula.

for example:
Actual 20
Actual 30
Actual 25
Actual 25
Estimate 25
Estimate 25

I want the formula to look at this data find the actuals and then get the average for the last three actuals.

2014-11-02 05:44:05

Shajid Hossain

I have a ledger sheet like bellow:

Date Dr. Cr. Balance
1/1/14 5000 --- 5000
2/1/14 ---- 500 4500
3/1/14 ---- 400 4000
4/1/14 1000 ---- 5000
5/1/14 ---- 100 4900
6/1/14 ---- 200 4700
7/1/14 ---- 700 4000

I need to know how long this current balance is carrying. It clear it from 3/1/14 to 7/1/14. How i calculate by one formula in excel.

2014-10-16 10:49:06

Barry

@Phil,

Assuming you are entring transaction information (date type/reference, amount) in columns A, B, and C, and that your running balance is in column D then the formula would be:

=INDIRECT("D"&COUNTA(C:C))

You can change the "D" to any column you like and it will return the corresponding value.
NB the caveats re blanks cells is still applicable as noted in the Tip.

2014-10-15 05:10:31

Jerry

This formula worked in finding the returning the value of the last row with number, but what should I do if I want to return the first row with data considering that some rows do not contain numbers.

=VLOOKUP(REPT("z",50),B:B,1)

2014-10-15 01:11:34

Phil

I have a check book balance sheet sort of thing made for a client.
He wants each month in a different tab.. so I need to carry over the last balance calculated… to the top of the next page automatically. So I want the last value output in the balance column.

Imagine a check book.. per row you have + or - and the calculated current balance.

Each month will obviously have a different # of entries, so I want to reference the last balance value in the series.

Here is the kicker.. and why I can't seem to get any of these suggestions to work.. I think.

The column that holds the values I want to reference, is filled with a formula that calculates that balance.
So I am not referencing a number… I am referencing a column of cells that contain formulas that either spits out a number, or a "" to stay hidden and not spit out those IRRITATING… "#VALUE!"s and such.

Thus.. each cell is a (=IF) that calculates the - & + on that row entry, if there is one.
Example.. in M10

=IF(B10="","",M9-(H10+I10+J10)+K10)

Logically I see it as.. Check if (B10) is blank (""), TRUE display nothing (""), FALSE.. then take the previous value (M9) and subtract possible costs (H10+I10+J10) and add any possible deposits (K10).
This formula repeats per line down the page waiting to be used.. or not.

I need a formula that will look at this column of formulas that either give "" or a # and get the last # in that series.
I am looking to display it on the current page at the bottom first… so getting it to the next page is easy and not my concern.
My concern is that all the suggestions I have found spit out "#VALUE!" or gives an error.

I have made a lot of complicated spreadsheets, but haven't really gotten into combining formulas or adding extra symbols to them to bend excel to my will. So I keep failing here. PLEASE HELP!

2013-10-10 10:27:21

Michael (Micky) Avidan

To find the last row that holds an AlphaNumeric value - you can use:

=MATCH("*",\$A:\$A,-1)

In order to return the last cells row in a Mixed column INCLUDING EMPTY(!) cells - use:

=MAX(MATCH(9^15,A:A),MATCH(CHAR(255),A:A,1))

Michael (Micky) Avidan
“Microsoft® Answers" - Wiki author & Forums Moderator
“Microsoft®” MVP – Excel (2009-2014)
ISRAEL

2013-10-10 04:17:55

Carl Colijn

I struggled with this one as well, but came to a better solution using array formula's.

Array formula's allow you to evaluate a formula on each cell in a range, so if you use the array formula:
=MAX(IF(A5:A500="",0,Row(A5:A500)))
then it will tell you the last used row, even if there are blanks in the range A5:A500. Keep in mind that you enter array formula's by pressing Ctrl-Shift-Enter. Excel will present the formula in curly { } braces for you, but you do not enter them yourselves.

You could even use the range A:A, but I do not know what impact that'll have on performance.

2013-06-04 06:19:34

Andrew McQuillen

Hi Jorge,
I have been looking at this for another issue i had.
Place this code in A55
=INDIRECT("a"&COUNTA(A1:A54)-0)
This will look at all the values between A1 and A54 and give you the last used value.
if you want to look at all the values in column A then you will need to move the piece of code to another location to avoid a circular reference error.
the code to look at the whole of column A is
=INDIRECT("a"&COUNTA(A:A)-0)
this will work in any cell which is not in column A.
NB there should be no missing cells of data ie nothing in row 4 but something in row 5. this will stop it working.
Hope this helps.
Andrew

2013-06-03 13:48:26

Jorge Vega

Need to get my last cell with data on to another cell.

A
1 \$213.00
2 \$256.33
3 \$100.00

I need to get A3 to A55 cell.
when A4 get updated then A55 will show A4.
When A5 get updated then A55 will show A5.

Hope you can help me here.

2012-07-05 21:53:57

Blaine

This works - I am able to use the last cell in a particular column in another cell - HOWEVER... what I want to [also] so is add the last cell from rows in other worksheets in the same workbook. How do I do that? What am I missing? Thanks!

##### This Site

Got a version of Excel that uses the menu interface (Excel 97, Excel 2000, Excel 2002, or Excel 2003)? This site is for you! If you use a later version of Excel, visit our ExcelTips site focusing on the ribbon interface.