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 :

[VBA-E]une boucle qui ne s'arrète pas


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    50
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 50
    Points : 32
    Points
    32
    Par défaut [VBA-E]une boucle qui ne s'arrète pas
    bonjour
    il faut à tout prix que je finisse ce projet d'ici ce soir (et je pense que je sature dur) mais je bloque sur une boucle qui ne fonctionne pas si quelqu'un peut me dire pourquoi ça serait super sympa
    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
    i = 2
    Do
    b = 2
    j = 2
     
    '
    'mise en place des incompatiblité par le père
    '
        Do
            j = j + 1
        Loop Until Sheets("généalogie").Cells(i, 3) = Sheets("Père_13").Cells(j, 1)
        Do
            b = b + 1
        Loop While Sheets("Père_13").Cells(j, b) <> 0
        Sheets("Père_13").Select
        Range(Cells(j, 2), Cells(j, b - 1)).Select
        Selection.Copy
        Sheets("incompat_chèvres_boucIA").Select
        Range(Cells(i, 2), Cells(i, b - 1)).Select
        ActiveSheet.Paste
    i = i + 1
    Loop Until Sheets("généalogie").Cells(i, 1) = 0

  2. #2
    Membre éprouvé
    Avatar de méphistopheles
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 551
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 551
    Points : 1 220
    Points
    1 220
    Par défaut
    1: quelle boucle ne s'arrète pas?

    2: si c'est la 1, on ne peut te répondre sans avoir le code interne.
    3: ton message est illisible, retire le jaune et met des balises [code]&#91;code&#93;&#91;/code&#93;
    4: essaye d'avoir une présentation claire avec des espaces.
    5:c'est urgent pour tout le monde, inutile de nous raconter ta vie, donne nous plutot des précisions sur ton projet.


    salut
    Méphistophélès
    Si la solution ne résout pas votre problème, changez le problème...
    Cours et tutoriels C++ - FAQ C++ - Forum C++.

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    Cells(i, 1)

    ou Cells(i, j)
    Elle est pas belle la vie ?

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    50
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 50
    Points : 32
    Points
    32
    Par défaut
    désolé
    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
    27
    28
    29
    dim i,b,j as integer
     
     
    i = 2
    Do
    b = 2
    j = 2
     
    '
    'mise en place des incompatiblité par le père
    '
        Do
            j = j + 1
        Loop Until Sheets("généalogie").Cells(i, 3) = Sheets("Père_13").Cells(j, 1)
     
        Do
            b = b + 1
        Loop While Sheets("Père_13").Cells(j, b) <> 0
     
        Sheets("Père_13").Select
        Range(Cells(j, 2), Cells(j, b - 1)).Select
        Selection.Copy
     
        Sheets("incompat_chèvres_boucIA").Select
        Range(Cells(i, 2), Cells(i, b - 1)).Select
        ActiveSheet.Paste
     
    i = i + 1
    Loop Until Sheets("généalogie").Cells(i, 1) = 0
    la boucle qui foire c'est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        Do
            j = j + 1
        Loop Until Sheets("généalogie").Cells(i, 3) = Sheets("Père_13").Cells(j, 1)

    j'ai deux feuilles généalogie et père_13
    je veux qu'il prenne la troisième cellule de chaque ligne de la feuille généalogie et qu'il l'a compare avec la première cellule de la feuille Père_13
    une fois q'il l'a trouvé la correspondance il copie le reste des données de la ligne Père_13 et la colle dans la feuille incompat_chèvres_boucIA

    Pour le caractère urgent c'est juste que je ne vois pas pourquoi ça déconne et ton histoire de balise je ne comprends pas non plus

    Balises ajoutées par ouskel'n'or
    Pense à mettre les balise code et /code

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Ce ne serait pas un pb de casse ?
    Si l'une de tes données a une majuscule que l'autre n'a pas, ton test foire
    j'essaierais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        Do 
            j = j + 1 
        Loop Until Ucase(Sheets("généalogie").Cells(i, 3)) = Ucase(Sheets("Père_13").Cells(j, 1))
    A+

    Les balises ? Tu as un bouton code au-dessus de la fenêtre d'édition de ton message : Tu sélectionnes le code et tu fais un clic sur le bouton. Tu verras, c'est magique !

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    50
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 50
    Points : 32
    Points
    32
    Par défaut
    mon code fonctionne merci pour tout c'est juste un souci au niveau des données excel
    merci pour les conseils

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    50
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 50
    Points : 32
    Points
    32
    Par défaut
    par contre comment faire pour connaitre le nombre de lignes avec des données afin d'inclure ça dans une boucle for next

  8. #8
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Pour connaître la dernière ligne renseignée de ta colonne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DernièreLigne = Cells(65535, NoColonne).End(xlUp).Row
    For i = 1 to DernièreLigne

    A+

  9. #9
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    50
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 50
    Points : 32
    Points
    32
    Par défaut
    merci beaucoup

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/04/2014, 10h39
  2. Variable d'une boucle qui ne se modifie pas
    Par Erast dans le forum Débuter
    Réponses: 4
    Dernier message: 17/04/2010, 20h25
  3. [SQL] une requête qui ne s'arrête pas ou si loin
    Par lodan dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 12/10/2006, 14h36
  4. Lancer une tâche planifiée qui ne s'arrête pas
    Par bart64 dans le forum Windows Serveur
    Réponses: 12
    Dernier message: 02/10/2006, 19h33
  5. [Tableaux] une boucle qui ne boucle pas
    Par taly dans le forum Langage
    Réponses: 9
    Dernier message: 19/09/2006, 17h25

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