VBA-イベント

VBA、イベント駆動型プログラミングは、セルまたはセル値の範囲を手動で変更したときにトリガーできます。変更イベントを使用すると作業が簡単になる場合がありますが、フォーマットでいっぱいのページをすばやく終了できます。イベントには2種類あります。

  • ワークシートイベント
  • ワークブックイベント

ワークシートイベント

ワークシートイベントは、ワークシートに変更があったときにトリガーされます。シートタブを右クリックして「コードの表示」を選択し、後でコードを貼り付けることで作成されます。

ユーザーは、これらのワークシートを1つずつ選択し、ドロップダウンから[ワークシート]を選択して、サポートされているすべてのワークシートイベントのリストを取得できます。

以下は、ユーザーが追加できるサポートされているワークシートイベントです。

Private Sub Worksheet_Activate() 
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)    
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean) 
Private Sub Worksheet_Calculate() 
Private Sub Worksheet_Change(ByVal Target As Range) 
Private Sub Worksheet_Deactivate() 
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink) 
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

ダブルクリックする前にメッセージを表示する必要があるとしましょう。

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
   MsgBox "Before Double Click"
End Sub

出力

セルをダブルクリックすると、次のスクリーンショットに示すように、メッセージボックスがユーザーに表示されます。

ワークブックイベント

ワークブックイベントは、ワークブック全体に変更があったときにトリガーされます。次のスクリーンショットに示すように、ドロップダウンから[ThisWorkbook]を選択し、[workbook]を選択することで、ワークブックイベントのコードを追加できます。次のスクリーンショットに示すように、Workbook_openサブプロシージャがユーザーにすぐに表示されます。

以下は、ユーザーが追加できるサポートされているワークブックイベントです。

Private Sub Workbook_AddinUninstall() 
Private Sub Workbook_BeforeClose(Cancel As Boolean) 
Private Sub Workbook_BeforePrint(Cancel As Boolean) 
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean) 
Private Sub Workbook_Deactivate() 
Private Sub Workbook_NewSheet(ByVal Sh As Object) 
Private Sub Workbook_Open() 
Private Sub Workbook_SheetActivate(ByVal Sh As Object) 
Private Sub Workbook_SheetBeforeDoubleClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetCalculate(ByVal Sh As Object) 
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 
Private Sub Workbook_SheetFollowHyperlink(ByVal Sh As Object, ByVal Target As Hyperlink) 
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_WindowActivate(ByVal Wn As Window) 
Private Sub Workbook_WindowDeactivate(ByVal Wn As Window) 
Private Sub Workbook_WindowResize(ByVal Wn As Window)

新しいシートが作成されるたびに、新しいシートが正常に作成されたことを示すメッセージをユーザーに表示する必要があるとしましょう。

Private Sub Workbook_NewSheet(ByVal Sh As Object)
   MsgBox "New Sheet Created Successfully"
End Sub

出力

新しいExcelシートを作成すると、次のスクリーンショットに示すように、ユーザーにメッセージが表示されます。