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 Office 365. You can find a version of this tip for the older menu interface of Excel here: Deleting Worksheet Code in a Macro.
Comprehensive VBA Guide Visual Basic for Applications (VBA) is the language used for writing macros in all Office programs. This complete guide shows both professionals and novices how to master VBA in order to customize the entire Office suite for their needs. Check out Mastering VBA for Office 2010 today!
Got a workbook cluttered with all sorts of macros? Delete them and you'll make your workbook easier to manage.
Discover MoreWhen you use a macro to process data you always run the risk of making that data unusable by Excel. This is especially ...
Discover MoreMacros that run automatically when you open or close a workbook are quite helpful. You may not want them to run, however, ...
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 © 2021 Sharon Parq Associates, Inc.
Comments