前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Excel VBA事件——Workbook

Excel VBA事件——Workbook

作者头像
xyj
发布2020-07-28 11:29:35
1.1K0
发布2020-07-28 11:29:35
举报
文章被收录于专栏:VBA 学习

Workbook事件中用的比较多的是:

  • Workbook_Open:文件打开后执行的代码
  • Workbook_BeforeClose:文件关闭前执行的代码

这两个事件在Office2007版本之前使用应该还是比较多的,那时候还没有Ribbon菜单,菜单是下拉式的,也就是和VBA编辑器菜单是一样的。

那时候运行代码除了插入按钮来运行之外,用的比较多的就是自定义一个菜单来运行,2007版本之后仍然是可以使用的,但是因为有了Ribbon菜单,所以一般是不建议再去创建下拉式菜单了。

用程序创建下拉式菜单后,如果不删除菜单将会一直存在,所以当时的代码一般处理方式是在Workbook_Open中创建菜单,然后在Workbook_BeforeClose中删除菜单:

代码语言:javascript
复制
Private Sub Workbook_BeforeClose(Cancel As Boolean)
    '删除菜单
End Sub

Private Sub Workbook_Open()
   '创建菜单
End Sub

Workbook_BeforeClose中有个参数Cancel,我们知道VBA中默认的参数传递是传地址的,所以在Workbook_BeforeClose内部是可以去改变Cancel的值的,你可以尝试加一个语句Cancel = True,然后再去点击关闭按钮关闭Excel,会发现已经关闭不了了。

Cancel的意思是取消,把取消设置为True的意思就是要取消某个操作,而在这里,这个操作就是Close工作簿,所以Excel就不会关闭了。

上面说的是2007版本之前用的比较多的一个场景,这两个事件还可以用在其他很多地方。

比如一个程序文件有一些配置信息是存储在外部的,那么就可以使用Workbook_Open事件在文件打开的时候去读取。

同时,配置信息又是可以修改的,一般会设置在Excel单元格中进行修改,那么这些修改的信息又要存储到外部,为了避免忘记这个操作,就可以把信息存储的过程放到Workbook_BeforeClose中,这样读取、保存配置信息就不会遗忘了,Workbook的事件会自动帮助完成。

Workbook中还有许多其他的事件,可以多去试试,结合自己使用Excel的情况看看是不是有适合的。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 VBA 学习 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档