Written by Allen Wyatt (last updated October 10, 2020)
This tip applies to Excel 2007, 2010, 2013, 2016, 2019, and Excel in Microsoft 365
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 Excel in Microsoft 365. You can find a version of this tip for the older menu interface of Excel here: Deleting Worksheet Code in a Macro.
Solve Real Business Problems Master business modeling and analysis techniques with Excel and transform data into bottom-line results. This hands-on, scenario-focused guide shows you how to use the latest Excel tools to integrate data from multiple tables. Check out Microsoft Excel 2013 Data Analysis and Business Modeling today!
When creating macros, you'll often have a need to select different cells in the worksheet. Here's how to select the first ...
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 MoreDoes your macro need to allow the user to specify a particular file name that should be used by the macro? Here's a quick ...
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 © 2023 Sharon Parq Associates, Inc.
Comments