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

VBA Access Discussion :

Boucle DO, incrementation si condition pas respectée [AC-2003]


Sujet :

VBA Access

  1. #1
    Membre habitué Avatar de jubourbon
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 540
    Points : 189
    Points
    189
    Par défaut Boucle DO, incrementation si condition pas respectée
    Bonjour,

    J'ai une boucle Do... Loop dans mon code, et je souhaiterais que lorsque une condition n'est pas respecté je revienne au do.
    Voici le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Do Until iCOunt<=52
    If maFonctionExterne()=false Then
    iCount=iCOunt+1
    Else
    'Ici je souhaiterais retourner au Do
    End If
    Loop
    J'ai essayé un Loop, un Next mais il ne veut pas. Quelqu'un à une idée.

    D'avance merci.
    Les meilleures sauces de salade sont sur www.sauce-salade.com
    SpBreak la pause SharePoint: SP Break

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Qu'entends-tu par revenir au Do ? Avec ton code actuel c'est déjà ce que tu fais.

    Veux-tu reinitialiser la valeur de iCOunt ? Réévaluer la condition ? Ne rien faire dans le else sous condition ?

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  3. #3
    Membre habitué Avatar de jubourbon
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 540
    Points : 189
    Points
    189
    Par défaut
    Oui désolé en relisant mon code je vois qu'il manque une partie importante

    Le voici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Do Until iCOunt<=52
    If maFonctionExterne()=false Then
    iCount=iCOunt+1
    Else
    'Ici je souhaiterais retourner au Do
    End If
    'Ici j'ai du code que je ne souhaite pas exécuter si je passe dans le else
    Loop
    Par conséquent, je ne souhaite pas exécuter le code après le if si je passe dans le else et revenir au do.
    Je pourrait mettre un boolean, mais n'y a t il pas une instruction pour cela?
    Les meilleures sauces de salade sont sur www.sauce-salade.com
    SpBreak la pause SharePoint: SP Break

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Do Until iCOunt<=52
     
       If maFonctionExterne()=false Then
           iCount=iCOunt+1
           'Ici j'ai du code que je ne souhaite pas exécuter si je passe dans le else
         Else
           'Ici je souhaiterais retourner au Do
           'Ne rien faire
       End If
     
    Loop
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Do Until iCOunt<=52
     
       If maFonctionExterne()=false Then
           iCount=iCOunt+1
         Else
           'Ici je souhaiterais retourner au Do
           'Ne rien faire
       End If
     
       If maFonctionExterne()=false Then
           'Ici j'ai du code que je ne souhaite pas exécuter si je passe dans le else
       end if
     
    Loop
    Enfin la moins recommandée des solutions

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Do Until iCOunt<=52
        If maFonctionExterne()=false Then
            iCount=iCOunt+1
           Else
             goto ProchainPas
         End If
     
         'Ici j'ai du code que je ne souhaite pas exécuter si je passe dans le else
     
    :ProchainPas
    Loop
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

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

Discussions similaires

  1. condition pas respectée et atof :(
    Par membreComplexe12 dans le forum C++
    Réponses: 8
    Dernier message: 06/12/2012, 19h36
  2. [MySQL] Les conditions de ma requête ne sont pas respectées
    Par babou54 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 13/02/2008, 12h28
  3. Réponses: 2
    Dernier message: 06/04/2006, 09h17
  4. boucle que je n'arrive pas à réaliser...
    Par mussara dans le forum Langage
    Réponses: 2
    Dernier message: 10/03/2006, 12h24
  5. [VBA-E]une boucle qui ne s'arrète pas
    Par vivelesgnous dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 15/02/2006, 18h05

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