Excel VBA事件——Workbook
Workbook事件中用的比较多的是:
- Workbook_Open:文件打开后执行的代码
- Workbook_BeforeClose:文件关闭前执行的代码
这两个事件在Office2007版本之前使用应该还是比较多的,那时候还没有Ribbon菜单,菜单是下拉式的,也就是和VBA编辑器菜单是一样的。
那时候运行代码除了插入按钮来运行之外,用的比较多的就是自定义一个菜单来运行,2007版本之后仍然是可以使用的,但是因为有了Ribbon菜单,所以一般是不建议再去创建下拉式菜单了。
用程序创建下拉式菜单后,如果不删除菜单将会一直存在,所以当时的代码一般处理方式是在Workbook_Open中创建菜单,然后在Workbook_BeforeClose中删除菜单:
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的情况看看是不是有适合的。
- 【技术专栏】OpenVirteX体系结构之组件(一)
- 洞察 | 深圳数据分析师的职业前景如何?爬完拉勾数据给你分析 (附代码和过程)
- 【温故】金融数据挖掘之朴素贝叶斯
- 为你的网站加上SSL,可以使用HTTPS进行访问
- LeeCX - 开源后台管理系统简单介绍
- fastdfs 图片服务器 使用java端作为客户端上传图片
- Shiro系列(3) - What is shiro?
- 干货|用python抓取摩拜单车API数据并做可视化分析(源码)
- 干货|机器学习:Python实现聚类算法之K-Means
- 美团点餐—listview内部按钮点击事件
- C4C和CRM里获取当前登录用户分配的Organization Unit信息
- 使用Excel调用ABAP系统的函数
- 如何计算并测量ABAP及Java代码的环复杂度Cyclomatic complexity
- 漫谈版本控制系统
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Spring Boot 2.2都有哪些新变化
- Go语言(十四)日志项目
- 如何在Spring Boot中使用Cookies
- 在SpringBoot中使用flyway管理数据库版本状态
- 使用Spring Data JPA进行数据分页与排序
- 搭建一个高可用负载均衡的集群架构(第二部分)
- 在PyTorch中使用Seq2Seq构建的神经机器翻译模型
- 理解 ECMAScript 规范(1)
- 使用 NodeJS 实现 JWT 原理
- 搭建一个高可用负载均衡的集群架构(第一部分)
- Java Stream函数式编程第三篇:管道流结果处理
- MySQL慢查询日志
- Pandas处理时间序列数据的20个关键知识点
- CentOS7下的LNMP环境搭建Dedecms网站
- 持久层框架JPA与Mybatis该如何选型