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]PB sur une boucle for each next


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juillet 2004
    Messages
    42
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Juillet 2004
    Messages : 42
    Points : 28
    Points
    28
    Par défaut [VBA-E]PB sur une boucle for each next
    Bonjour, ma boucle ci dessus s'arrête dès qu'elle rencontre une cellule avec la valeur "ALL", alors qu'elle doit rechercher sur l'ensemble des cellules d'une plage nommée. D'où le for each c in.....
    et je comprend pas pourquoi le next c ne passe pas?
    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
    For Each c In Plage
                    c = ActiveCell.Value
     
                        If c = "CE637000_FEJ" Then
                                If ActiveCell.Offset(0, -2).Value <> "ALL" Then
                                    MsgBox ActiveCell.Offset(0, -2).Value
                                    MsgBox ActiveCell.Address
                                    ActiveCell.EntireRow.Delete
                                End If
     
     
     
                        End If
     
                    Next c
    Merci.

  2. #2
    Membre régulier Avatar de biggione
    Inscrit en
    Juillet 2006
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 99
    Points : 91
    Points
    91
    Par défaut
    utilise plutot ceci voir ci ca marche:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    For Each u In Plage.count
                    c = ActiveCell.Value
     
                        If c = "CE637000_FEJ" Then
                                If ActiveCell.Offset(0, -2).Value <> "ALL" Then
                                    MsgBox ActiveCell.Offset(0, -2).Value
                                    MsgBox ActiveCell.Address
                                    ActiveCell.EntireRow.Delete
                                End If
     
                        End If
     
                    Next u

  3. #3
    Inactif  
    Avatar de jmfmarques
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3 784
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3 784
    Points : 4 674
    Points
    4 674
    Par défaut
    ce qui saute au yeux est ceci , dans la boucle :
    c = ActiveCell.Value

    If c = "CE637000_FEJ" Then
    Il est bien évident que ne saurait de cette façon être traitée une autre cellule que celle contenant la valeur "CE637000_FEJ"

    C'est à peu prés l'équivalent de :
    je veux traiter tous les légumes mais ignorerai tout ce qui n'est pas le navet !!!
    Elle est bien bonne, celle-là !

  4. #4
    Nouveau membre du Club
    Inscrit en
    Juillet 2004
    Messages
    42
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Juillet 2004
    Messages : 42
    Points : 28
    Points
    28
    Par défaut
    J'ai modifié mon code de la manière suivante:

    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
    For Each c In Plage
                    Valeurlue = c
     
                        If Valeurlue = "CE637000_FEJ" Then
                        Cpt = Cpt + 1
                                'If ActiveCell.Offset(0, -2).Value <> "ALL" Then
                                    'MsgBox ActiveCell.Offset(0, -2).Value
                                    'MsgBox ActiveCell.Address
                                    ActiveCell.EntireRow.Delete
     
                                'End If
     
     
                        End If
              Next c
    Msgbox Cpt

    il efface certes les bonnes lignes, mais pas toutes celles qui vérifient ma condition? c'est à dire que mon Cpt doit me remonter 1 si je relance la macro, car seule une ligne comporte la valeur ALL et CE637000_FEJ.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 172
    Points : 99
    Points
    99
    Par défaut
    euh question de newbie mais c'est normal que ton code comporte des ', concrétement cela les réduits à des simples commentaires non ?
    et au lieu de répéter 3 fois active cell, tu peux faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     With Active Cell ....
    End With
    Je me trompes ?

    Désolé si j'ai insulté ton éventuelle expérience de VBA, je débutes totalement

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Février 2006
    Messages
    932
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 932
    Points : 448
    Points
    448
    Par défaut
    Mouarf retournes à tes problemes !!!

    bon aller je vais te répondre.

    ca t'a bon !


    mais with activecell, le code doit toujours commencer par activecell. Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    with activecell
        .Offset(0, -2).Value
        .EntireRow.Delete
    end with
    si t'a

    tu peux pas mettre ton with

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 172
    Points : 99
    Points
    99
    Par défaut
    Yeah 50 % de bonnes réponses

  8. #8
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 040
    Points
    20 040
    Par défaut
    Citation Envoyé par Elstak
    ..

    mais with activecell, le code doit toujours commencer par activecell. ...
    essai :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    With ActiveCell
      MsgBox "Adresse : " & .Address & " Locale : " & .AddressLocal & " Ligne :  " & .Row _
       & " Colonne " & .Column & " Valeur : " & .Value
     End With

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Février 2006
    Messages
    932
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 932
    Points : 448
    Points
    448
    Par défaut
    chut !!


  10. #10
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 172
    Points : 99
    Points
    99
    Par défaut
    oho le score monte à 75 % de bonnes réponses.
    La moitié des points seulement car sur le principe j'avais bon mais je ne voyais pas cela comme ca

Discussions similaires

  1. [XL-2007] Copier coller plage de cellules dans une boucle For Each..Next
    Par JulieD33 dans le forum Excel
    Réponses: 3
    Dernier message: 02/03/2015, 11h19
  2. Problème sur une boucle For Each
    Par nanoo79 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/11/2014, 09h14
  3. Lenteur d'une boucle For each next
    Par Val2000 dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 27/05/2013, 11h41
  4. comment effacer un element dans un collection dans une boucle for each
    Par medkarim dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 17/10/2008, 12h48
  5. [MySQL] problème sur une boucle for
    Par leclone dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 28/12/2006, 10h33

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