VBA工作薄工作表事件一览表修订稿

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

V B A工作薄工作表事件
一览表
集团标准化工作小组 [Q8QX9QT-X8QQB8Q8-NQ8QJ8-M8QMN]
翻箱倒柜,无意中发现个好东东
放到这里,大家查着也方便
工作簿对象事件一览表
当工作簿更改、工作簿中的任何工作表更改、加载宏更改或数据透视表更改时,将引发工作簿事件。

工作簿上的事件在默认情况下是可用的。

若要查看工作簿的事件过程,请用鼠标右键单击处于还原状态或最小化状态的工作簿窗口标题栏,再单击快捷菜单上的“查看代码”。

在“过程”下拉列表框内选择事件名称。

事件说明
Activate
激活工作薄时
AddinInstall
当工作簿作为加载宏安装时
AddinUninstall
工作簿作为加载宏卸载时
BeforeClose
关闭工作薄前
BeforePrint
打印工作薄(或其中任何内容)之前
BeforeSave
保存工作薄前
Deactivate
工作簿从活动状态转为非活动状态时
NewSheet
在工作簿中新建工作表时
Open
打开工作簿时
PivotTableCloseConnection
在数据透视表关闭与其数据源的连接之后
PivotTableOpenConnection
在数据透视表打开与其数据源的连接之后
SheetActivate
激活任何一张表时
SheetBeforeDoubleClick
双击任何工作表时
SheetBeforeRightClick
鼠标右键单击任一工作表时
SheetCalculate
工作表重新计算时
SheetChange
更改工作表中的单元格时
SheetDeactivate
任一工作表由活动状态转为非活动状态时
SheetFollowHyperlink
单击 Microsoft Excel 中的任意超链接时
SheetPivotTableUpdate
数据透视表的工作表更新之后
SheetSelectionChange
工作簿中的数据透视表更新之后
WindowActivate
工作簿的窗口激活时
WindowDeactivate
工作簿的窗口变为非活动状态时
WindowResize
工作簿窗口调整大小时
本示例在打开工作簿时将 Microsoft Excel 窗口最大化。

Sub Workbook_Open()
= xlMaximized
End Sub
Activate 事件
激活一个工作簿、工作表、图表或嵌入图表时产生此事件。

Private Sub object_Activate()
object Chart、Workbook、或者 Worksheet。

有关对 Chart 对象使用事件的详细信息,请参阅图表对象事件的用法。

说明
切换两个显示同一个工作簿的窗口时,将产生 WindowActivate 事件,但不产生工作簿的 Activate 事件。

新建窗口时不产生本事件。

示例
当激活工作表时,本示例对 A1:A10 区域进行排序。

Private Sub Worksheet_Activate()
Range("a1:a10").Sort Key1:=Range("a1"), Order:=xlAscending
End Sub
AddinInstall 事件
当工作簿作为加载宏安装时,产生此事件。

Private Sub Workbook_AddinInstall()
示例
当指定工作簿作为加载宏安装时,本示例将一个控件添加到常用工具栏中。

Private Sub Workbook_AddinInstall()
With ("Standard").
.Caption = "The AddIn's menu item"
.OnAction = "''!Amacro"
End With End Sub
End Sub
AddinUninstall 事件
当工作簿作为加载宏卸载时,产生此事件。

Private Sub Workbook_AddinUninstall()
说明
卸载加载宏时,该加载宏并不自动关闭。

示例
当指定工作簿作为加载宏卸载时,本示例将 Microsoft Excel 最小化。

Private Sub Workbook_AddinUninstall()
= xlMinimized
End Sub
BeforeClose 事件
在关闭工作簿之前,先产生此事件。

如果该工作簿已经更改过,则本事件在询问用户是否保存更改之前产生。

Private Sub Workbook_BeforeClose(Cancel As Boolean)
Cancel 当事件产生时为 False。

如果该事件过程将本参数设为 True,则停止对工作簿的关闭操作,工作薄仍处于打开状态。

示例
本示例将 BeforeClose 事件的响应设置为保存工作簿的任何更改。

Private Sub Workbook_BeforeClose(Cancel as Boolean)
If = False Then
End Sub
BeforePrint 事件
在打印指定工作簿(或者其中的任何内容)之前,产生此事件。

Private Sub Workbook_BeforePrint(Cancel As Boolean)
Cancel 当事件产生时为 False。

如果该事件过程将本参数设为 True,则当该过程运行结束之后不打印工作簿。

示例
本示例在打印之前对当前活动工作簿的所有工作表重新计算。

Private Sub Workbook_BeforePrint(Cancel As Boolean)
For Each wk in Worksheets
Next
End Sub
BeforeSave 事件
保存工作簿之前产生此事件。

Private Sub Workbook_BeforeSave(ByVal SaveAsUi As Boolean, Cancel As Boolean)
SaveAsUi 如果显示“另存为”对话框,则为 True。

Cancel 当事件产生时为 False。

如果该事件过程将本参数设为 True,则该过程执行结束之后不保存工作簿。

示例
本示例在保存工作簿之前询问用户是否保存。

Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, _
Cancel as Boolean)
a = MsgBox("Do you really want to save the workbook", vbYesNo)
If a = vbNo Then Cancel = True
End Sub
Deactivate 事件
图表、工作表或工作簿从活动状态转为非活动状态时产生此事件。

Private Sub object_Deactivate()
object Chart、Workbook 或者 Worksheet。

有关对 Chart 对象使用事件的详细信息,请参阅 Chart 对象事件的用法。

示例
本示例当工作簿转为非活动状态时,对所有打开的窗口进行排列。

Private Sub Workbook_Deactivate()
xlArrangeStyleTiled
End Sub
NewSheet 事件
当在工作簿中新建工作表时产生此事件。

Private Sub Workbook_NewSheet(ByVal Sh As Object)
Sh 新工作表。

可以是一个 Worksheet 或 Chart 对象。

示例
本示例将新建的工作表移到工作簿的末尾。

Private Sub Workbook_NewSheet(ByVal Sh as Object)
After:= Sheets
End Sub
Open 事件
打开工作簿时,将产生本事件。

Private Sub Workbook_Open()
示例
每次打开工作簿时,本示例都最大化 Microsoft Excel 窗口。

Private Sub Workbook_Open()
= xlMaximized
End Sub
PivotTableCloseConnection 事件
发生在数据透视表关闭与其数据源的连接之后。

Private Sub expression_PivotTableCloseConnection(ByVal Target As PivotTable)
expression 引用在类模块中带有事件声明的 Workbook 类型对象的变量。

Target 必需。

选定的数据透视表。

示例
本示例显示一则消息,说明数据透视表与其数据源的连接已经关闭。

本示例假定您已在类模块中声明了带有事件的 Workbook 类型的对象。

Private Sub ConnectionApp_PivotTableCloseConnection(ByVal Target As PivotTable)
MsgBox "The PivotTable connection has been closed."
End Sub
PivotTableOpenConnection 事件
发生在数据透视表打开与其数据源的连接之后。

Private Sub expression_PivotTableOpenConnection(ByVal Target As PivotTable)
expression 引用在类模块中带有事件声明的 Workbook 类型对象的变量。

Target 必需。

选定的数据透视表。

示例
本示例显示一则消息,说明数据透视表与其数据源的连接已经打开。

本示例假定您已在类模块中声明了带有事件的 Workbook 类型的对象。

Private Sub ConnectionApp_PivotTableOpenConnection(ByVal Target As PivotTable)
MsgBox "The PivotTable connection has been opened."
End Sub
SheetActivate 事件
当激活任何一张表时产生此事件。

Private Sub object_SheetActivate(ByVal Sh As Object)
object Application 对象或 Workbook 对象。

Sh 激活的表。

可以是一个 Chart 对象或 Worksheet 对象。

示例
本示例显示每一张激活的表的名称。

Private Sub Workbook_SheetActivate(ByVal Sh As Object)
MsgBox
End Sub
SheetBeforeDoubleClick 事件
当双击任何工作表时产生此事件,此事件先于默认的双击操作发生。

Private Sub object_SheetBeforeDoubleClick(ByVal Sh As Object, ByVal Target As Range, ByVal Cancel As Boolean)
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Sh 代表该工作表的 Worksheet 对象。

Target 当双击事件发生时最靠近鼠标指针的单元格。

Cancel 当事件发生时为 False。

如果事件过程将该参数设为 True,则该过程执行完之后将不进行默认的双击操作。

说明
图表不产生该事件。

示例
本示例关闭默认的双击操作。

Private Sub Workbook_SheetBeforeDoubleClick(ByVal Sh As Object, _
ByVal Target As Range, ByVal Cancel As Boolean)
Cancel = True
End Sub
SheetBeforeRightClick 事件
当用鼠标右键单击任一工作表时产生此事件,此事件先于默认的右键单击操作。

Private Sub object_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, ByVal Cancel As Boolean)
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Sh 代表该工作表的 Worksheet 对象。

Target 当右键单击事件发生时最靠近鼠标指针的单元格。

Cancel 当事件产生时为 False。

如果该事件过程将本参数设为 True,则该过程执行结束之后将不执行默认的右键单击操作。

说明
图表不产生该事件。

示例
本示例关闭默认的右键单击操作。

有关其他示例的详细信息。

请参阅BeforeRightClick 事件示例。

Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, _
ByVal Target As Range, ByVal Cancel As Boolean)
Cancel = True
End Sub
SheetCalculate 事件
当对工作表重新计算或者在图表上重新绘制发生更改的数据点时产生此事件。

Private Sub object_SheetCalculate(ByVal Sh As Object)
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Sh 工作表。

可以是一个 Chart 对象或 Worksheet 对象。

示例
当计算工作簿中的任何工作表时,本示例对第一张工作表的 A1:A100 区域进行排序。

Private Sub Workbook_SheetCalculate(ByVal Sh As Object)
With Worksheets(1)
.Range("a1:a100").Sort Key1:=.Range("a1")
End With
End Sub
SheetChange 事件
当用户更改工作表中的单元格或者外部链接引起单元格的更改时,产生此事件。

Private Sub object_SheetChange(ByVal Sh As Object, ByVal Source As Range)
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Sh 代表该工作表的 Worksheet 对象。

Source 发生更改的区域。

说明
图表不产生该事件。

示例
当任一工作表发生更改时,运行本示例。

Private Sub Workbook_SheetChange(ByVal Sh As Object, _
ByVal Source As Range)
' runs when a sheet is changed
End Sub
SheetDeactivate 事件
当任一工作表由活动状态转为非活动状态时产生此事件。

Private Sub object_SheetDeactivate(ByVal Sh As Object)
object Application 对象或 Workbook 对象。

Sh 工作表。

可以是一个 Chart 对象或 Worksheet 对象。

示例
本示例显示每一非活动工作表的名称。

Private Sub Workbook_SheetDeactivate(ByVal Sh As Object)
MsgBox
End Sub
SheetFollowHyperlink 事件
单击 Microsoft Excel 中的任意超链接时发生此事件。

对于工作表级的事件,请参阅“帮助”主题中的 FollowHyperlink 事件。

Private Sub Workbook_SheetFollowHyperlink(ByVal Sh As Object, ByVal Target As Hyperlink)
Sh Object 类型,必需。

表示包含该超链接的 Worksheet 对象。

Target Hyperlink 类型,必需。

一个 Hyperlink 对象,该对象代表超链接的目标位置。

示例
本示例对当前工作簿中所有已单击过的超链接保留一个列表或历史记录,其中也包括含有这些超链接的工作表名称。

Private Sub Workbook_SheetFollowHyperlink(ByVal Sh as Object, _
ByVal Target As Hyperlink)
& ":" &
End Sub
SheetPivotTableUpdate 事件
发生在数据透视表的工作表更新之后。

Private Sub expression_SheetPivotTableUpdate(ByVal Sh As Object, Target As PivotTable)
expression 引用在类模块中带有事件声明的 Applicaton 类型或 Workbook 类型对象的变量。

Sh 必需。

选定的工作表。

Target 必需。

选定的数据透视表。

示例
本示例显示一则消息,说明数据透视表已经更新。

本示例假定您已在类模块中声明了带有事件的 Application 类型或 Workbook 类型的对象。

Private Sub ConnectionApp_SheetPivotTableUpdate(ByVal shOne As Object, Target As PivotTable)
MsgBox "The SheetPivotTable connection has been updated."
End Sub
SheetSelectionChange 事件
任一工作表上的选定区域发生更改时,将产生本事件。

(但图表上的选定对象发生改变时,不会产生本事件。

)
Private Sub object_SheetSelectionChange(ByVal Sh As Object, ByVal Target As
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Sh 新选定的区域所在的工作表。

Target 新选定的区域。

示例
本示例在状态栏上显示选定区域所在的工作表名称及选定区域的地址。

Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, _
ByVal Target As
= & ":" &
End Sub
WindowActivate 事件
工作簿的窗口激活时,将产生本事件。

Private Sub object_WindowActivate(ByVal Wb As , ByVal Wn As
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Wb 仅用于 Application 对象。

显示在活动窗口中的工作簿。

Wn 激活的窗口。

示例
本示例使工作簿窗口激活时最大化。

Private Sub Workbook_WindowActivate(ByVal Wn As
= xlMaximized
End Sub
WindowDeactivate 事件
工作簿的窗口变为非活动状态时,将产生本事件。

Private Sub object_WindowDeactivate(ByVal Wb As , ByVal Wn As object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Wb 仅用于 Application 对象。

非活动状态的窗口中的工作簿。

Wn 非活动状态的窗口。

示例
本示例使工作簿窗口变为非活动状态时最小化。

Private Sub Workbook_WindowDeactivate(ByVal Wn As
= xlMinimized
End Sub
WindowResize 事件
工作簿窗口调整大小时,将产生本事件。

Private Sub object_WindowResize(ByVal Wb As , ByVal Wn As
object Application 对象或 Workbook 对象。

有关对 Application 对象使用事件的详细信息,请参阅 Application 对象事件的用法。

Wb 仅用于 Application 对象。

在调整大小的窗口中显示的工作簿。

Wn 调整大小的窗口。

示例
工作簿窗口调整大小时,将运行本示例。

Private Sub Workbook_WindowResize(ByVal Wn As = & " resized"
End Sub。

相关文档
最新文档