Personnaliser les préférences

Nous utilisons des cookies pour vous aider à naviguer efficacement et à exécuter certaines fonctions. Vous trouverez ci-dessous des informations détaillées sur tous les cookies sous chaque catégorie de consentement.

Les cookies classés comme « Nécessaires » sont stockés sur votre navigateur car ils sont essentiels pour activer les fonctionnalités de base du site.... 

Toujours actif

Necessary cookies are required to enable the basic features of this site, such as providing secure log-in or adjusting your consent preferences. These cookies do not store any personally identifiable data.

Aucun cookie à afficher.

Functional cookies help perform certain functionalities like sharing the content of the website on social media platforms, collecting feedback, and other third-party features.

Aucun cookie à afficher.

Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics such as the number of visitors, bounce rate, traffic source, etc.

Aucun cookie à afficher.

Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.

Aucun cookie à afficher.

Advertisement cookies are used to provide visitors with customized advertisements based on the pages you visited previously and to analyze the effectiveness of the ad campaigns.

Aucun cookie à afficher.

VBA : comment exécuter une macro lorsque la valeur d’une cellule change



Vous pouvez utiliser la syntaxe suivante dans VBA pour exécuter une macro lorsqu’une valeur de cellule spécifique change :

Sub Worksheet_Change(ByVal Target As Range)
    If Target.Address = "$A$1" Then
        Call MultiplyMacro
    End If
End Sub

Cet exemple particulier entraînera l’exécution de la macro appelée MultiplyMacro lorsque la valeur de la cellule A1 change.

L’exemple suivant montre comment utiliser cette syntaxe dans la pratique.

Exemple : exécuter une macro lorsque la valeur d’une cellule change à l’aide de VBA

Supposons que nous créions la macro suivante appelée MultiplyMacro qui multiplie les valeurs des cellules A1 et B1 et affiche les résultats dans la cellule C1 :

Sub MultiplyMacro()
    Range("C1") = Range("A1") * Range("B1")
End Sub

Par exemple, supposons que nous ayons la valeur 12 dans la cellule A1 et la valeur 3 dans la cellule B1 .

Si nous exécutons cette macro, nous recevrons le résultat suivant :

Supposons maintenant que nous souhaitions exécuter automatiquement cette macro chaque fois que la valeur de la cellule A1 change.

Pour ce faire, nous pouvons faire un clic droit sur le nom de la feuille puis cliquer sur Afficher le code :

Dans la fenêtre d’édition de code qui apparaît, on peut coller le code suivant :

Sub Worksheet_Change(ByVal Target As Range)
    If Target.Address = "$A$1" Then
        Call MultiplyMacro
    End If
End Sub

La capture d’écran suivante montre comment procéder en pratique :

Nous pouvons ensuite fermer l’éditeur VB.

Désormais, chaque fois que nous modifions la valeur dans la cellule A1 , la macro appelée MultiplyMacro s’exécutera automatiquement et effectuera une multiplication en utilisant la nouvelle valeur dans la cellule A1 .

Par exemple, supposons que nous modifions la valeur de la cellule A1 en 10 . Dès que nous modifions la valeur et appuyons sur Entrée , la macro s’exécutera :

La macro multiplie 10 par 3 et affiche le résultat dans la cellule C2 .

Remarque : Si vous souhaitez exécuter la macro lorsqu’une cellule d’une plage spécifique change, vous pouvez utiliser la syntaxe suivante :

Sub Worksheet_Change(ByVal Target As Range)
    If Not Intersect(Target, Range("A1:B1")) Is Nothing Then
        Call MultiplyMacro
    End If
End Sub

Cela entraînera l’exécution de la macro appelée MultiplyMacro si une cellule de la plage A1: B1 change.

Ressources additionnelles

Les didacticiels suivants expliquent comment effectuer d’autres tâches courantes dans VBA :

VBA : Comment compter le nombre de feuilles dans un classeur
VBA : Comment extraire des données d’un autre classeur
VBA : Comment ajouter de nouvelles feuilles

Ajouter un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *