Workbook_Open和Auto_Open都能实现在打开工作簿时自动运行自定义代码的功能 。Workbook_Open似乎要取代Auto_Open,而Auto_Open的存在似乎只是为了兼容以前的程序 。然而,对于Excel开发人员来说,Auto_Open仍然很有用 。
对于初学者来说,细致地了解Workbook_Open和Auto_Open,解开对这两个过程的一些疑惑,有助于更好地学习或阅读相关代码,也能够更好地在自已编写的代码中合理使用它们 。
Workbook_Open和Auto_Open放置的位置不同
Workbook_Open必须位于ThisWorkbook模块中,而Auto_Open必须放置在标准模块中,如下图所示 。
文章插图
在ThisWorkbook模块中,可以直接在VBE编辑器上方左边的下拉框中选择Workbook,代码框架会自动生成 。
文章插图
在标准模块中,必须手动输入Sub Auto_Open() 。
Application.EnableEvents事件的影响
Workbook_Open受Application.EnableEvents事件的影响,而Auto_Open不会 。也就是说,当Application.EnableEvents事件设置为False后,Excel不会触发Workbook_Open 。因此,如果你担心因Application.EnableEvents事件设置而影响打开工作簿时自动运行自定义的代码,那么可以使用Auto_Open,这样不管Application.EnableEvents事件的状态如何,都能确保用户打开工作簿时执行自定义代码 。
注:在打开工作簿的同时按住SHIFT键,会禁用Workbook_Open()和Auto_Open() 。
使用代码自动打开工作簿时的影响
如果使用代码自动打开含有Workbook_Open或Auto_Open的工作簿,那么将不会触发Auto_Open代码但会触发Workbook_Open代码 。因此,Auto_Open适合于由用户自已打开的工作簿,而不适用于由编写的代码自动打开的工作簿 。也就是说,如果您仅想让用户自已打开时执行自定义的代码,那么使用Auto_Open 。
如果想要在自动打开工作簿时禁用Workbook_Open,那么可以在打开该工作簿前设置Application.EnableEvents事件为False 。
如果想要在自动打开工作簿时运行Auto_Open,那么可以使用Workbook.RunAutoMacros方法 。
Workbook_Open和Auto_Open同时存在时的调用顺序
如果某工作簿中同时存在Workbook_Open和Auto_Open,那么将首先调用Workbook_Open 。在Workbook_Open和Auto_Open调用完后,再执行customUI_OnLoad()回调程序 。即,工作簿打开时的调用顺序:
【Workbook_Open与Auto_Open是一样的吗?】Workbook_Open
Auto_Open
customUI_OnLoad()
推荐阅读
- 龙血树生长特性与养护指南
- Peace Lily 护理指南与和平百合毒性
- Pothos 植物护理指南与绿萝中毒的迹象
- 骨碎补的功效与作用有哪些
- 鸡骨草的功效与作用
- 粑粑柑与丑橘有什么不同
- 怎么实现图表文本与单元格文本的链接?
- 芦笋炒肉片的做法
- 凉拌芦笋怎么做好吃
- 红烧虾怎么做好吃