Excel 2010 VBA 入门 074 工作表事件之Workbook_SheetChange

目录

示例

实现代码

插入模块

插入工作薄事件

工作簿的Workbook_SheetChange事件

工作簿的Workbook_Activate事件

事件的组合


示例

    当需要保护某个工作表不被修改时,一般可以将其保护。在VBA中,是否可以设置一个工作表名称的列表(如图所示),当工作表属于该列表中时则不允许改变。该如何实现?

实现代码

    编写一个备份工作表的程序,将当前活动工作表备份,然后在工作簿的Workbook_SheetChange事件中查找其Sh参数所表示的工作表是否属于保护工作表的列表,若属于该列表,则删除当前工作表,并使用备份工作表重命名之前的工作表。

插入模块

Option Explicit

Sub BackupSht()
    Dim shtOld As Worksheet
    Dim shtNew As Worksheet
    
    '禁止屏幕刷新
    Application.EnableEvents = False
    Application.DisplayAlerts = False
    
    '记录当前活动工作表
    Set shtOld = ActiveSheet
    '若当前活动工作表不是保护工作表时
    If Not shtOld Is Sheet1 Then
        On Error Resume Next
        '显示备份工作表并删除
        ThisWorkbook.Worksheets("tmp&
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ngbshzhn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值