VBA - Événements

VBA, une programmation événementielle peut être déclenchée lorsque vous modifiez manuellement une cellule ou une plage de valeurs de cellule. L'événement de changement peut faciliter les choses, mais vous pouvez très rapidement terminer une page pleine de mise en forme. Il existe deux types d'événements.

  • Événements de la feuille de travail
  • Événements du classeur

Événements de la feuille de travail

Les événements de feuille de calcul sont déclenchés lorsqu'il y a un changement dans la feuille de calcul. Il est créé en effectuant un clic droit sur l'onglet de la feuille et en choisissant «afficher le code», puis en collant le code.

L'utilisateur peut sélectionner chacune de ces feuilles de calcul et choisir «Feuille de travail» dans la liste déroulante pour obtenir la liste de tous les événements de feuille de travail pris en charge.

Voici les événements de feuille de calcul pris en charge qui peuvent être ajoutés par l'utilisateur.

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)

Exemple

Disons qu'il suffit d'afficher un message avant de double-cliquer.

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

Production

En double-cliquant sur n'importe quelle cellule, la boîte de message s'affiche à l'utilisateur comme indiqué dans la capture d'écran suivante.

Événements du classeur

Les événements du classeur sont déclenchés en cas de modification du classeur dans son ensemble. Nous pouvons ajouter le code pour les événements de classeur en sélectionnant `` Ce classeur '' et en sélectionnant `` classeur '' dans la liste déroulante, comme indiqué dans la capture d'écran suivante. Immédiatement, la sous-procédure Workbook_open est affichée à l'utilisateur, comme illustré dans la capture d'écran suivante.

Voici les événements de classeur pris en charge qui peuvent être ajoutés par l'utilisateur.

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)

Exemple

Disons que nous avons juste besoin d'afficher un message à l'utilisateur indiquant qu'une nouvelle feuille est créée avec succès, chaque fois qu'une nouvelle feuille est créée.

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

Production

Lors de la création d'une nouvelle feuille Excel, un message est affiché à l'utilisateur comme indiqué dans la capture d'écran suivante.