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: Deleting Blank Columns.

Deleting Blank Columns

by Allen Wyatt
(last updated June 21, 2018)


When importing information from an external source, it is possible that the data will contain blank columns—columns with nothing in them. If you import a lot of data, then deleting these columns can be a bother. There are a couple of ways you can approach how to delete these columns.

The first approach works very well if your data is sorted by column. In other words, the data that you import is in ascending order, or you want it in sorted order. In this case, follow these steps:

  1. Select the columns that represent your data. Make sure you select, as part of the range, all the blank columns as well.
  2. Choose the Sort option from the Data menu. Excel displays the Sort dialog box.
  3. Click the Options button. Excel displays the Sort Options dialog box. (See Figure 1.)
  4. Figure 1. The Sort Options dialog box.

  5. Choose the Sort Left to Right radio button.
  6. Click on OK to dismiss the Sort Options dialog box.
  7. Using the first Sort By drop-down list, specify the row by which you want to sort.
  8. Click on OK.

When sorting in this manner, all the empty columns end up "pushed" to the right, and your data is in a sorted order.

If you don't want your data sorted, then you can use a nifty macro that will check for blank columns in a selected range and then delete those columns. The following macro will do the trick:

Sub DeleteEmptyColumns()
    first = Selection.Column
    last = Selection.Columns(Selection.Columns.Count).Column
    For i = last To first Step -1
      If WorksheetFunction.CountBlank(ActiveSheet.Columns(i)) = 65536 Then
      End If
    Next i
End Sub

To use the macro, select the range of columns in which you want blank columns deleted. The macro steps through the columns and if the column is truly blank, it is deleted. You should note that this macro will delete only columns that are truly empty. If cells within a column include a formula that returns a zero value (and you have the display of zeros values turned off) or that returns an empty string, then the column isn't empty—it contains formulas. In this case, the column won't be deleted.


If you would like to know how to use the macros described on this page (or on any other page on the ExcelTips sites), I've prepared a special page that includes helpful information. Click here to open that special page in a new browser tab.

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2660) 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: Deleting Blank Columns.

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


Finding Information in the Registry

The Registry is the central depository of configuration information used by Windows and by programs running on your ...

Discover More

Exiting a For ... Next Loop Early

If you use For ... Next loops in your macros, make sure you give a way to jump out of the loop early. That way you can ...

Discover More

Setting the Width for Row Labels

Excel displays, by default, a row label or heading at the left side of each row on the screen. As you scroll down the ...

Discover More

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!

More ExcelTips (menu)

Deleting Duplicate Text Values

Got a list of data from which you want to delete duplicates? There are a couple of techniques you can use to get rid of ...

Discover More

Checking for Duplicate Rows Based on a Range of Columns

When working with data in Excel, you might want to figure out which rows of data represent duplicates of other rows. If ...

Discover More

Stopping the Deletion of Cells

You can delete cells from a worksheet, and Excel will move the remaining cells either to the left or upwards. Deletions, ...

Discover More

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

View most recent newsletter.


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 three less than 5?

2014-05-29 10:24:44


Hi sushama.

I have written a macro for you, which will do what you are looking for. Please note the following "conditions":

1. Your data is expected to be in a grid of 8 columns and 40 rows. The grid can be anywhere on the sheet.

2. You MUST position the cursor at the top left cell of the grid.

3. Before you run the macro, you need to find a column that has no data. Insert the column NUMBER (NOT the letter) in the code so that it is assigned to the variable SC (sorting column). I have used 150, which is beyond the range of most spreadsheets!

Two steps to the process:
1. Copy the data to a single column, but only the non-empty cells.
2. Write the new column of cells back to the original grid.
In both cases, clear the cells as you go.

I hope you find this useful. Here is the code.



Sub ShiftCells()
Dim x As Integer ' top left corner row
Dim y As Integer ' top left corner column
Dim i As Integer ' loop counter
Dim j As Integer ' loop counter
Dim MaxX As Integer ' max row
Dim MaxY As Integer ' max column
Dim a As Integer ' counter for new column
Dim SC As Integer ' sort column

x = Selection.Row
y = Selection.Column
a = 1
SC = 150

MaxX = x + 39
MaxY = y + 7

' write the cell values to a new column
For j = y To MaxY
For i = x To MaxX
If Cells(i, j) <> "" Then ' if the cell has a value then
Cells(a, SC) = Cells(i, j) ' copy the value
a = a + 1
End If
Cells(i, j) = "" ' clear the original cell
Next i
Next j

' write the corrected list back
a = 1
For j = y To MaxY
For i = x To MaxX
If Cells(a, SC) <> "" Then
Cells(i, j) = Cells(a, SC) ' copy the values
Cells(a, SC) = "" ' clear the corrected cells
a = a + 1
Exit For
End If
Next i
Next j

End Sub

2013-04-18 01:02:13


We have listed book no. in excel sheet in ascending order for stock verification. Some of the books have been weeded out, which leaves blank cells in the sheet. So how to delete these cells without disturbing the sequential order. The no. are in 8 columns and 40 rows in every sheet. i.e.41 no. comes on the second colum and so on.. Pl. guide

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.

Newest Tips

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

(Your e-mail address is not shared with anyone, ever.)

View the most recent newsletter.