Excel.Tips.Net Welcome toExcel.Tips.Net

Helpful Links

Tips.Net Home
ExcelTips Home
Ask an Excel Question
Make a Comment

Tips.Net Store

ExcelTips FAQ
ExcelTips Premium

Learn Access Now
Free Printable Forms

Beauty Tips
Car Tips
Cleaning Tips
College Tips
Cooking Tips
Excel2007 Tips
ExcelTips
Family Tips
Gardening Tips
Health Tips
Home Tips
Legal Tips
Money Tips
Organizing Tips
Pest Tips
Pet Tips
Wedding Tips
Word2007 Tips
WordTips

Advertise on the
ExcelTips Site

Newest Tips

Removing Borders

Converting to Octal

Filtering Columns for Unique Values

Printing Multiple Worksheets on a Single Page

Changing the Default Font

Creating a Drawing Object

Determining a Value of a Cell

 

Progression Indicator in a Macro

Summary: If you use macros to process data in a workbook, it can often appear like the macro is doing nothing, even though it is working hard behind the scenes. This is the time when you need some sort of indicator on-screen to let users know that the macro is, indeed, working away. (This tip works with Microsoft Excel 97, Excel 2000, Excel 2002, Excel 2003, and Excel 2007.)

Macros are often created to process data, and processing data can often take a long time. Because of this, some users may think that their computer has stopped responding, even though the macro is busy chunking away a it's appointed task.

The solution for most macro developers is to somehow alert users as to the progress of the macro. There are two ways that you can do this in Excel. The simplest and most common approach is to use the status bar to indicate what the macro is doing. All you need to do is put together a string that contains the status message, and then assign that string to the StatusBar property of the Application object, as shown here:

sStatus = "Processing Input File - Please Be Patient"
Application.StatusBar = sStatus

The message stays on the status bar until you overwrite it with some other message. You could also indicate progress in a loop by giving the percentage complete:

For x = 1 to y
    Application.StatusBar = Format(x/y,"0.0%") & " Complete"
' Other coding here
Next

When your routine finishes, return the status bar back to normal with the following statement:

    Application.StatusBar = False

If you prefer to develop an actual progress indicator for the macro, you can do so by creating a UserForm and then updating the form to display a "percentage bar" or some other visual indicator. Most people who desire this type of progress indicator rely on a variation of John Walkenbach's solution, found at this address:

http://www.j-walk.com/ss/excel/tips/tip34.htm

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (3223) applies to Microsoft Excel versions: 97 | 2000 | 2002 | 2003 | 2007

Change Formatting Based On Your Data! Conditional formatting provides a way for you to adjust the appearance of your data based on the data itself. Discover how to put this amazingly powerful feature to work for you, today. This comprehensive volume is available in two editions.
 
Check out Excel Conditional Formatting today!