Please Note: This article is written for users of the following Microsoft Excel versions: 2007, 2010, 2013, 2016, 2019, Excel in Microsoft 365, and 2021. If you are using an earlier version (Excel 2003 or earlier), this tip may not work for you. For a version of this tip written specifically for earlier versions of Excel, click here: Recovering Macros from Corrupted Workbooks.
Written by Allen Wyatt (last updated August 31, 2024)
This tip applies to Excel 2007, 2010, 2013, 2016, 2019, Excel in Microsoft 365, and 2021
Devarajan ran into a situation where a workbook became corrupted, but he wanted to recover the macro module that was associated with the workbook. (The macros represented quite a bit of development time.) Devarajan wondered how the module could be recovered.
The answer depends, in large part, on how corrupted the workbook really is and where the corruption is located within the workbook. Much has been written about how to recover corrupted workbooks; the following resources will be of interest in this regard:
https://support.microsoft.com/en-us/office/7abfc44d-e9bf-4896-8899-bd10ef4d61ab https://support.microsoft.com/en-us/office/153a45f4-6cab-44b1-93ca-801ddcd4ea53 https://jkp-ads.com/articles/corruptfiles.asp
These pages refer specifically to recovering data, not to recovering the macros in a module associated with a workbook. One thing that you might try in order to get your macros is the following:
Another way to attempt recovery is to use OpenOffice, a free alternative to Microsoft Office. The spreadsheet program in OpenOffice will open Excel files, and it isn't as sensitive to some corruption issues.
Still another approach is to use a tool that will specifically extract macros from a workbook. Doing this can get pretty techie, but if you are so inclined, you may find the discussion and tools at this site of interest:
https://www.decalage.info/vba_tools
If this still doesn't work, try using a low-level file manipulation tool that allow you to read files sector by sector from a disk, and then allow you to see the information in each sector. With most types of files this won't be very helpful. In fact, it wouldn't help you recover any data from an Excel workbook. Recovering macros is a different story, however. They are stored in the workbook in plain ASCII text, so you should be able to recognize the macro code and then copy it from the disk tool.
Finally, if you spend a lot of time developing macros (as Devarajan apparently does), then you may want to build into your development routine a way to backup your macros. There are many ways you could do this, but a very simple way is to simply export the module(s) in which your macros are stored. That way you'll have them available in plain text format, in a BAS file, that you can access and read with any text editor.
Note:
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (12712) applies to Microsoft Excel 2007, 2010, 2013, 2016, 2019, Excel in Microsoft 365, and 2021. You can find a version of this tip for the older menu interface of Excel here: Recovering Macros from Corrupted Workbooks.
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!
Macros can make your use of Excel much more powerful. If you have a macro that is triggered by an on-screen button, you ...
Discover MoreDo you need to know how many times a worksheet has been used? Excel doesn't track that information, but you can develop ...
Discover MoreWhen writing macros, you may want to position a message box at a specific location on the screen. This can't be done in ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
2024-08-31 10:06:39
J. Woolley
Also, consider https://www.thevbahelp.com/vbe-extras
Got a version of Excel that uses the ribbon interface (Excel 2007 or later)? This site is for you! If you use an earlier version of Excel, visit our ExcelTips site focusing on the menu 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