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: Preserving the Undo List.
Written by Allen Wyatt (last updated January 9, 2021)
This tip applies to Excel 97, 2000, 2002, and 2003
As you are working in Excel, there is a bit of a "safety net" in place in regards to changes you make. Most people know that if they mess things up, they can quickly press Ctrl+Z or choose the Undo command from the Edit menu or by using the Undo tool on the toolbar. If you don't like what you just did, you can easily undo it and get back to the way things were before.
When you run a macro, however, the macro doesn't "play nice" with the Undo list. In fact, running a macro completely erases the Undo list, and therefore you cannot automatically undo the effects of running the macro. There is no intrinsic command—in Excel or in VBA—to preserve the Undo list. There are a couple of ways that you can approach the problem, however.
If you feel that you might want to undo the effects of a macro, the first thing you can do is to save your workbook before running the macro. This, in effect, gives you a "pre-macro" version of the workbook. If you want to later revert to this version, simply close the workbook without saving and then reload it from disk.
Another option is to rethink the way you do your macros. If you have a macro that does a lot of processing of information in your worksheet, code the macro so that it maintains, in memory, the state of anything that it changes. You can then create a separate macro that reads this information and effectively undoes the effects of the first macro.
To make this approach really handy, the last step in your primary macro can be to "stuff" information on the Undo stack. This info can then be used, but the user, to "undo" macro that you created. For instance, the following macro command could be the last one in your primary macro:
Application.OnUndo "Primary Macro", "UndoPrimary"
After this command, when the user looks at the Undo list, he or she will see the text "Primary Macro." If they choose this option from the Undo list, then your "undo" macro (UndoPrimary) is executed.
You should note that this approach doesn't save what was on the Undo list before you ran the macro—there seems no way to do that. When your primary macro is through running, there will only be a single option available on the Undo list: Primary Macro.
Note:
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2060) 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: Preserving the Undo List.
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!
If you use Excel to create a macro-based application, you may want to make sure that your programs cease working after a ...
Discover MoreMacros are great for working with strings, and one of the most commonly used string functions is Len. This tip explains ...
Discover MoreWhen you use a macro to do file operations, it works (by default) within the current directory. If you want to know which ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
There are currently no comments for this tip. (Be the first to leave your comment—just use the simple form above!)
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.
FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
Copyright © 2024 Sharon Parq Associates, Inc.
Comments