Written by Allen Wyatt (last updated April 22, 2024)
This tip applies to Excel 2007, 2010, 2013, 2016, 2019, and 2021
Jean-Louis would like to write a VBA procedure that deletes the code attached to a specific worksheet. He knows how to delete procedures stored in modules, but not how to do it when they are stored in the sheet.
The good news is that if you know how to delete macros within a module, you can apply the same technique to delete it within a sheet. The difference is that you would use the sheet name rather than the module name when referring to the component you want to delete.
For instance, if you are referring to code in a module in a workbook, you normally do it by referencing the module in this manner:
ActiveWorkbook.VBProject.VBComponents("Module1")
To refer to code contained within a worksheet, you would use this syntax, instead:
ActiveWorkbook.VBProject.VBComponents("Sheet1")
For other ideas about how to reference VBA code in various ways from within other macros, refer to the following page at Chip Pearson's site:
http://www.cpearson.com/excel/vbe.aspx
Note:
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (9490) applies to Microsoft Excel 2007, 2010, 2013, 2016, 2019, and 2021. You can find a version of this tip for the older menu interface of Excel here: Deleting Worksheet Code in a Macro.
Create Custom Apps with VBA! Discover how to extend the capabilities of Office 365 applications with VBA programming. Written in clear terms and understandable language, the book includes systematic tutorials and contains both intermediate and advanced content for experienced VB developers. Designed to be comprehensive, the book addresses not just one Office application, but the entire Office suite. Check out Mastering VBA for Microsoft Office 365 today!
Need to know if a particular cell is clicked with the mouse? Excel has no particular event handler for clicking in this ...
Discover MoreThere are multiple ways that Excel can create a workbook, and the formatting in each creation method can be different. In ...
Discover MoreNeed to know the character code used for a particular character? In a macro you can use the Asc function to determine the ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
2020-10-10 13:03:15
J. Woolley
Sorry. The correct reference is https://excelribbon.tips.net/T007612_Deleting_VBA_Code_in_a_Copied_Worksheet.html
2020-10-10 13:01:11
J. Woolley
Also, see https://excelribbon.tips.net/T007612_Deleting_VBA_Code_in_a_Copied_Worksheet.html#comment-form-hd
2020-10-10 11:31:55
J. Woolley
This procedure will delete the code in a specific worksheet:
Sub DeleteWorksheetCode(WS As Worksheet)
With WS.Parent.VBProject.VBComponents(WS.Name).CodeModule
.DeleteLines 1, .CountOfLines
End With
End Sub
When I tested using Excel 365, it was not necessary to include a Reference to Microsoft Visual Basic for Applications Extensibility 5.3.
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 © 2025 Sharon Parq Associates, Inc.
Comments