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.
Best-Selling VBA Tutorial for Beginners Take your Excel knowledge to the next level. With a little background in VBA programming, you can go well beyond basic spreadsheets and functions. Use macros to reduce errors, save time, and integrate with other Microsoft applications. Fully updated for the latest version of Office 365. Check out Microsoft 365 Excel VBA Programming For Dummies today!
The data stored in a worksheet can often correspond to information external to that worksheet. For instance, you might ...
Discover MoreIf your macro closes workbooks, you'll want to make sure that it will save any changes you made to the workbook. Here's ...
Discover MoreUsing a macro to add worksheets to your workbook is easy. This tip provides two different methods you can use.
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