VBA学习笔记三(VBA事件)

VBA事件

执行宏的方法

执行宏的方法:
1、在写好的代码处点击一下,然后点击执行
2、点击宏,选中代码名后执行
3、将宏与表格中的按钮绑定,点击按钮便执行宏
4、双击选中待操作的表格,在上面选中worksheet,此时后面的事件发生时,执行下面代码,截图如下
在这里插入图片描述

工作表事件

事件说明
Activate激活工作表时
Deactivete工作表从活动状态转化为非活动状态时
BeforeDoubleClick双击工作表时
BeforeRightClick右键单击工作表时
Calculate对工作表进行重新计算之后
Change更改工作表中的单元格,或外部链接引起单元格变化时
FollowHyperlink单击工作表上的任意链接时
PivotTableUpdate在工作表中的数据透视表更新之后
SelectionChange工作表上的选定区域发生变化时

事件操作示例

根据表格中的内容自动筛选数据

在这里插入图片描述

问题:
从左侧数据中筛选出L3中该部门的数据,并将其复制到右侧
当L3中的数据变化时,右侧数据会自动更新
注意
由于在该项目中采用的时事件变化时执行宏操作,故在事件中选择Change,此时应该考虑虽然当表格L3中的数据变化时,会执行宏操作,但是当将筛选出来的数据填写至右侧表格时,依然会检测到表格变化,因此在检测到第一次表格变化时,将事件检测器关闭,关闭语句如下:

Application.EnableEvents = False
Application.EnableEvents = True

整体代码+注释

Private Sub Worksheet_Change(ByVal Target As Range)

Application.EnableEvents = False
'首先将右侧内容清空
Range("l1:q10000").ClearContents
'开启筛选
Range("A1:F232").AutoFilter Field:=4, Criteria1:=Sheet1.Range("i2").Value
'复制
Range("a1:f232").Copy Range("l1")
'关闭筛选
Range("A1:F232").AutoFilter

Application.EnableEvents = True


End Sub

参考

参考:王佩丰老师教学视频链接: https://www.bilibili.com/video/BV1L4411Q7Ni?p=1.

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值