IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Calcul dans une macro évènementielle


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Septembre 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2010
    Messages : 18
    Par défaut Calcul dans une macro évènementielle
    Bonjour,
    Dans une macro évènementielle, je souhaite agir sur un ensemble de cellules, en fonction du résultat d'un calcul apparaissant dans la colonne 10 (J) de mon tableau. Avec mon code, l'évènement se produit seulement lorsque le rentre manuellement la valeur dans la cellule. Pouvez-vous m'aidez ? Voici mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub Worksheet_Change(ByVal Target As Range)
    Application.EnableEvents = False
    If Target.Column = 10 Then
    If Target.Value > 1 Then
    Range(Target, Target.Offset(0, -5)).Interior.ThemeColor = xlThemeColorAccent2
    Range(Target, Target.Offset(0, -5)).Interior.TintAndShade = 0.8
    Else
    Range(Target, Target.Offset(0, -5)).Interior.Pattern = xlNone
    End If
    End If
    Application.EnableEvents = True
     
    End Sub

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2009
    Messages : 652
    Par défaut
    Bonjour,

    Essayez avec votre code modifié
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    Private Sub Worksheet_Change(ByVal Target As Range)
    Dim R As Range
    On Error Resume Next
    Set R = Target.Dependents
    If Err = 0 Then
      Application.EnableEvents = False
      If R.Column = 10 Then
        If R.Value > 1 Then
          Range(R, R.Offset(0, -5)).Interior.ThemeColor = xlThemeColorAccent2
          Range(R, R.Offset(0, -5)).Interior.TintAndShade = 0.8
        Else
          Range(R, R.Offset(0, -5)).Interior.Pattern = xlNone
        End If
      End If
      Application.EnableEvents = True
    End If
    Err.Clear
    On Error GoTo 0
     
    '/// éventuels autres traitements ///
     
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Septembre 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2010
    Messages : 18
    Par défaut
    Bonjour,
    Ca fonctionne très bien.
    Il fallait donc agir sur les dépendants (Set R = Target.Dependents) de ma cellules. J'ai encore appris quelque chose.
    Je commençais à désespérer car je n'avais pas de réponse.

    Merci beaucoup
    Eric

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/07/2014, 14h17
  2. [XL-2010] Problème événement Calculate dans une macro
    Par benadry dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 15/04/2014, 09h27
  3. Réponses: 1
    Dernier message: 22/05/2010, 14h58
  4. Recuperer un champ calculé dans une variable....
    Par vijeo dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 21/12/2004, 14h57
  5. calcul dans une requête
    Par blaz dans le forum Langage SQL
    Réponses: 8
    Dernier message: 22/12/2003, 10h31

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo