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 :

Récupération ancienne valeur


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut Récupération ancienne valeur
    Bonjour,

    Dans la macro ci-dessous lorsque l'utilisateur clique sur non dans la msgbox, la valeur de la cellule ne revient à la valeur OldValue.

    Merci pour votre aide.

    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
    23
    Private Sub Worksheet_Change(ByVal Target As Range)
        Dim NewValue, OldValue
        Dim Cellule As Range
        If Target.Address <> "$C$16" Then Exit Sub
        Application.EnableEvents = False
        With Target
            NewValue = .Value
            Application.Undo
            OldValue = .Value
            .Value = NewValue
        End With
        MsgBox "Old Value: " & OldValue & vbCrLf & "New Value: " & NewValue
     
        If reponse = MsgBox("Penses-tu que ce soit vrai ?", vbYesNo + vbCritical) = vbYes Then
            MsgBox ("La valeur est changée")
                If reponse = vbNo Then
                    Set Cellule = Range("C16")
                        Cellule.Value = OldValue
                End If
                Debug.Print OldValue
        End If
        Application.EnableEvents = True
    End Sub

  2. #2
    Expert confirmé Avatar de Patrice740
    Homme Profil pro
    Retraité
    Inscrit en
    Mars 2007
    Messages
    2 478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2007
    Messages : 2 478
    Par défaut
    Bonjour,

    Par exemple :
    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
    23
    24
    25
    26
    Option Explicit
    Private Sub Worksheet_Change(ByVal Target As Range)
    Dim NewValue, OldValue
    Dim reponse As Integer
    Dim msg As String
      If Target.Address = "$C$16" Then
        With Target
          Application.EnableEvents = False
          NewValue = .Value
          Application.Undo
          OldValue = .Value
          .Value = NewValue
          Application.EnableEvents = True
        End With
        msg = "Old Value: " & OldValue & vbCrLf & "New Value: " & NewValue
        reponse = MsgBox(msg & vbCrLf & "Penses-tu que ce soit vrai ?", vbYesNo + vbCritical)
        If reponse = vbYes Then
          MsgBox ("La valeur est changée")
        ElseIf reponse = vbNo Then
          Application.EnableEvents = False
          Target.Value = OldValue
          Application.EnableEvents = True
        End If
        Debug.Print msg
      End If
    End Sub

  3. #3
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut
    Bonjour,
    Merci cela fonctionne.
    Pourquoi le premier code ne fonctionnait pas ?
    Bonne journée.

  4. #4
    Expert confirmé Avatar de Patrice740
    Homme Profil pro
    Retraité
    Inscrit en
    Mars 2007
    Messages
    2 478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2007
    Messages : 2 478
    Par défaut
    Bonjour,

    Citation Envoyé par joponta Voir le message
    Merci cela fonctionne
    Évidement, je ne vais pas te proposer un code qui ne fonctionne pas !!!

    Pourquoi le premier code ne fonctionnait pas ?
    Comme l'aurait dit Jacques II de Chabannes de La Palice : à cause d'un code mal conçu !

    Pour comprendre pourquoi, il suffit de placer un point d'arrêt en début de procédure, de continuer en pas à pas en analysant les différentes variables à chaque pas.
    A lire : Le débogage sous Visual Basic 6 et VBA

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

Discussions similaires

  1. [checkbox] Récupération des valeurs de checkbox
    Par chng001 dans le forum Struts 1
    Réponses: 13
    Dernier message: 07/09/2009, 21h31
  2. [struts] [checkbox] récupération des valeurs cochées
    Par abourell dans le forum Struts 1
    Réponses: 16
    Dernier message: 10/06/2005, 21h58
  3. Réponses: 8
    Dernier message: 09/03/2005, 11h47
  4. récupération de valeur de lien
    Par sex-sansbol dans le forum ASP
    Réponses: 3
    Dernier message: 07/06/2004, 11h43
  5. Récupération de valeurs d'un tableau
    Par leeloo076 dans le forum ASP
    Réponses: 12
    Dernier message: 25/03/2004, 11h59

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