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!
VBA is a versatile programming language. It is especially good at working with string data. Here are the different VBA ...
Discover MoreIf you need to know whether a particular value is odd or even, you can use this simple formula. Designed to be used in a ...
Discover MoreDo you get tired of the dialog box that says "do you want to enable macros" that is displayed when you open a workbook. ...
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