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 :

Des MsgBox successives


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Responsable de compte
    Inscrit en
    Juillet 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable de compte

    Informations forums :
    Inscription : Juillet 2015
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Des MsgBox successives
    Bonjour à tous !

    Je suis nouveau ici et j'essaye d'apprendre le VBA en autodidacte du mieux que je peux.

    Voici mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    If MsgBox("Voulez-vous vérifier la TVA sur les débits?", vbYesNo, "Vérif RAN TVA débits") = vbYes Then
        For i = 13 To DL
            If Sheets(1).Range("D" & i) = "RAN" Then
                Sheets(1).Range("B" & i).Select
                If MsgBox("La facture suivante (tiers : " & Range("B" & i) & " ) est-elle soummise à TVA sur les débits?", vbYesNoCancel, "Vérif TVA débits") = vbYes Then
                    Sheets(1).Range("N" & i) = Sheets(1).Range("K" & i)
                End If
                If MsgBox("La facture suivante (tiers : " & Range("B" & i) & " ) est-elle soummise à TVA sur les débits?", vbYesNoCancel, "Vérif TVA débits") = vbCancel Then Exit For
            End If
        Next i
    End If
    Le problème de ce code est comme je ne sais pas bien définir, pour chaque type de réponse à la MsgBox, une action, il ne marche pas. En effet, ma MsgBox s'affiche 2 fois à chaque fois. Par contre mise à part ce problème, le comportement des réponses est OK.

    Merci d'avance pour votre aide.

    Cordialement.

  2. #2
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    747
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 747
    Points : 1 332
    Points
    1 332
    Par défaut
    Bonjour Kuartz,

    ma MsgBox s'affiche 2 fois à chaque fois
    Oui, tu l'as mis 2 fois dans le code
    Il faut que tu expliques en français le comportement que tu aimerais obtenir pour qu'on puisse te guider sur la structure du code

  3. #3
    Membre émérite
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Novembre 2011
    Messages
    1 503
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Irlande

    Informations professionnelles :
    Activité : Chef de projet en SSII

    Informations forums :
    Inscription : Novembre 2011
    Messages : 1 503
    Points : 2 657
    Points
    2 657
    Par défaut
    Bonjour Kuartz, tototiti2008,

    Les conditions sont mal exécutées. Ainsi tu réaffiches les MsgBox au lieu de stocker la valeur saisie par l'utilisateur.

    Un exemple très simple se trouve ici.
    On trouve un Select Case. Mais, cela est identique avec la structure If, ElseIF, Else et End If.

    N'hésite pas à revenir vers moi.

    Cordialement,
    Kimy
    La logique :
    • Plus ya de gruyère, moins ya de gruyère.
    • Plus tu pédales moins vite, moins tu avances plus vite.
    Plusoyer les réponses pertinentes et n'oublier pas de résolver en fin de post !

  4. #4
    Membre actif
    Homme Profil pro
    Enthousiaste Excel
    Inscrit en
    Avril 2015
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enthousiaste Excel

    Informations forums :
    Inscription : Avril 2015
    Messages : 155
    Points : 242
    Points
    242
    Par défaut
    Bonjour,

    Recupère UNE FOIS le résultat de la msgbox dans une variable
    gener :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    dim a as variant
    a = MsgBox("Voulez-vous vérifier la TVA sur les débits?", vbYesNo, "Vérif RAN TVA débits")
    et ENSUITE tu peux utiliser cette variable <a> dans une condition

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if a = vbYes Then
    ...
    End If
    Cela n'affichera la box qu'une fois.

Discussions similaires

  1. TIKZ & PGF, comment faire des rotations successives
    Par saih_tam dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 1
    Dernier message: 20/05/2009, 15h38
  2. Macro de validation des MsgBox
    Par FIFI33160 dans le forum VBA Access
    Réponses: 2
    Dernier message: 05/12/2007, 19h24
  3. Gestion des MsgBox
    Par sylnie dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 16/04/2007, 22h24
  4. [newb] faire des requêtes successives
    Par MatMeuh dans le forum Access
    Réponses: 1
    Dernier message: 06/07/2006, 09h40
  5. test entre des lignes successives d'une table
    Par preskovik dans le forum Access
    Réponses: 4
    Dernier message: 22/03/2006, 08h45

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