自删除宏(Microsoft Excel)
帕特里克(Patrick)正在编写宏,他希望宏在达到特定的到期日期后删除。有两种方法可以完成此任务。首先,您可以按照以下方式编写仅在特定日期之前起作用的宏:
Sub MyMacro() ExpirationDate = #1/1/2020# If Now() < ExpirationDate Then 'Rest of macro goes here End if End Sub
这个想法是,如果(在这种情况下)当前日期在2020年1月1日之前,则将执行宏的主体。如果是1月1日或更晚,则宏将不会执行。当然,这种方法实际上并没有删除宏。它只是检查宏是否在某个日期之前执行。
要真正摆脱宏代码,您需要采取另一种方法:
Private Sub Workbook_Open() Dim VBComp As VBIDE.VBComponent Dim VBComps As VBIDE.VBComponents 'Delete if Past Date If Date >= #1/1/2020# Then Set VBComps = ActiveWorkbook.VBProject.VBComponents For Each VBComp In VBComps Select Case VBComp.Type Case vbext_ct_StdModule, vbext_ct_MSForm, _ vbext_ct_ClassModule VBComps.Remove VBComp Case Else With VBComp.CodeModule .DeleteLines 1, .CountOfLines End With End Select Next VBComp End If Set VBComps = Nothing Set VBComp = Nothing End Sub
此代码改编自最初由Chip Pearson编写的宏,该宏可在其站点的以下地址找到:
http://www.cpearson.com/excel/vbe.aspx
若要使宏工作,您需要确保有对Microsoft Visual Basic for Applications Extensibility的引用。 (您可以通过在VB编辑器中选择“工具” |“引用”,然后在可用引用中选择“ Microsoft Visual Basic for Applications Extensibility”来执行此操作。)
该宏在打开工作簿时运行,如果日期大于或等于2020年1月1日,则将删除VBProject的每个组件。这意味着宏非常强大,因为它会删除所有内容,而不仅仅是单个过程或模块。
当然,使用此宏需要牢记一些事情。
首先,如果用户选择在打开工作簿时不启用宏,则此代码将永远不会运行,并且宏也不会被删除。
其次,以这种方式删除宏显然会导致对工作簿的更改。这意味着在关闭工作簿时,将询问用户是否要保存所做的更改。如果他们选择不这样做,则将不会保存删除,并且该宏将在下次打开工作簿时再次运行。
注意:
如果您想知道如何使用此页面(或_ExcelTips_网站上的任何其他页面)中描述的宏,我准备了一个特殊页面,其中包含有用的信息。
_ExcelTips_是您进行经济高效的Microsoft Excel培训的来源。
本技巧(12812)适用于Microsoft Excel 2007、2010、2013、2016、2019和Office 365中的Excel。您可以在此处为Excel的较早菜单界面找到此技巧的版本:
自删除宏。