Introduction | Example | Tutorial | Applications | Comments

Introduction - Application.ScreenUpdating = False

Prevent your screen from updating until your Excel macro is finished with Application.ScreenUpdating=False. The Application.ScreenUpdating property is useful when running macros that jump from cell to cell, sheet to sheet, and workbook to workbook.

Setting the Application.ScreenUpdating to False stops your screen from flickering (refreshing) as your macro runs. It can be used for other applications, but I find it most useful for Excel.

Example - Application.ScreenUpdating = False

Screen Updating Demonstration

Sub ScreenUpdatingDemo()
Application.ScreenUpdating = False
Range("a1").Select
For j = 1 To 10
    For i = 1 To 25
        Selection = i
        Selection.Offset(1, 0).Select
    Next i
    Selection.Offset(-25, 1).Select
Next j
Application.ScreenUpdating = True
End Sub

Write better macros in half the time
I see people struggling with Excel every day and I want to help. That's why I'm giving away my personal macro library for free. This powerful gift lets you automatically import all my macros directly into your spreadsheets with just one click.

I want to join the free wellsrPRO VBA Training program

Tutorial - Application.ScreenUpdating = False

This demo uses Selection.Offset to forcefully change the selected cell in Excel. I recommend disabling ScreenUpdating anytime you are manually selecting cells or worksheets. Play around with the Application.ScreenUpdating property to prove it works.

Change False to True in Line 2 to see what happens when you don’t disable screen updating. Your screen will show each action your VBA code performs.

Displaying each step slows your macro down. It’s a good practice to disable screen updating to decrease total run time. Don’t forget to set your ScreenUpdating property back to True when you’re done.

Application Ideas - Application.ScreenUpdating = False

The silly code I presented in the ScreenUpdating Demonstration just numbers cells. Better uses for Application.ScreenUpdating=False are presented below:

  1. Adding new Worksheets
  2. Manipulating Word Documents from Excel
  3. Sending email from Excel
  4. Switching between Excel Sheets.
  5. Opening new Excel Workbooks.
  6. Switching between pages in Word.

Comments

Leave a comment below and let me know how you plan on using Application.ScreenUpdating Property.


About The VBA Tutorials Blog

Ryan Wells

The VBA Tutorials Blog was created by Ryan Wells, a Nuclear Engineer and professional VBA Developer. He created this site to help others learn to write macros in Excel. That's why he developed a unique 3-part free Excel training program to help others quickly learn VBA in a natural setting: right inside Excel.