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 :

boucle qui ne tourne pas


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    192
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 192
    Par défaut boucle qui ne tourne pas
    Re-bonjour les pros,

    J'essaie de faire une boucle qui me permette de remplir les cellules de la colonne A, tant que les cellules de la colonne B sont renseignées. Voici mon "code":

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub boucle()
     
    Dim Intcount As Integer
    Do
    Intcount = Intcount + 1
    ActiveCell = Range("D9")
    Loop Until IsEmpty(ActiveCell.Offset(0, 1))
     
    End Sub
    Le problème c'est que cela renseigne seulement la première cellule de mon tableau, puis rien...comprends pas, ça fait que semaines que je travaille avec VBA...Quelqu'un a t-il une idée?

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 262
    Par défaut
    Tu ne peux pas supprimer les cellules vides ?

    Sinon si tu as une colonne complète à côté (cellules non-vides), tu peux faire une boucle sur la hauteur totale de ton tableau avec l'instruction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Range("C1").CurrentRegion.Rows.Count
    qui te renvoie le nombre de ligne de ton tableau... si la colonne C n'a pas de celulle vide :p

  3. #3
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    bonjour sash6

    je pense avoir compris le but de la boucle

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub boucle()
     
    Dim Intcount As Long
    Do
    Intcount = Intcount + 1
    cells(intcount ,1) = Range("D9")
    Loop Until IsEmpty(cell(intcout,2))
     
    End Sub
    met en place en colonne A la valeur de D9 tant qu'il y à une valeur en colonne B
    Attention : si tu as des formules en colonne B, Les cellules ne sont pas considérées comme vides

    Amicalement

  4. #4
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    192
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 192
    Par défaut
    bonjour wilfied 42,

    effectivement, c'est de cela qu'il s'agit! mais ça ne marche toujours pas, la boucle est bouclée sans avoir rempli les cellules.

  5. #5
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    re:

    j'ai laissé ton code comme il etait, mais la ligne commence à 1 dans ton code alors B1 doit pas etre vide

    de plus il est à l'envers le code, tu traites Forcement la premiere cellule A et tu testes la cellule B de la meme ligne pour faire la suivant

    personnellement je verrai plutot cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub boucle()
    Dim Intcount As Long
    intcount = 5 ' Initialisation de la premiere ligne a traiter
    Do while cells(intcount,2).value>""
    cells(intcount ,1) = Range("D9")
    Intcount = Intcount + 1
    Loop 
    End Sub
    @ te lire

  6. #6
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    192
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 192
    Par défaut
    a y est wil! En fait les cellules de la colonne B contenaient du menu déroulant, il fallait utiliser isempty

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub boucle()
     
    Dim Intcount As Long
    Do
    Intcount = Intcount + 1
    cells(intcount ,1) = Range("D9")
    Loop Until IsEmpty(cell(intcout,2))
     
    End Sub
    Petite question bête: si je veux que la boucle commence à partir de la ligne 16, je fais comment?

  7. #7
    Membre émérite
    Inscrit en
    Avril 2007
    Messages
    667
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Avril 2007
    Messages : 667
    Par défaut
    Je ne suis pas sur que IsEmpty soit bien adapte pour les cellules, une cellule vide contient une chaine vide, pas un objet non initialise.

    Utilise plutot un test du type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    While cells(i,j).value <> ""
    'ou 
    Until Cells(i,j).value = ""

  8. #8
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    192
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 192
    Par défaut
    Oohhh! le deuxième code marche encore mieux! t'as bien vu! merci et encore merci!

Discussions similaires

  1. SSIS Boucle For Loop qui ne tourne pas
    Par baime dans le forum SSIS
    Réponses: 2
    Dernier message: 17/01/2014, 15h50
  2. Code qui ne tourne pas.
    Par Mlezen dans le forum Octave
    Réponses: 4
    Dernier message: 19/06/2008, 14h41
  3. Réponses: 10
    Dernier message: 07/01/2007, 12h03
  4. [MySQL] Boucle qui ne fonctionne pas bien que la 1ère fois
    Par R.L. dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 27/05/2006, 21h59
  5. Réponses: 1
    Dernier message: 28/07/2005, 14h21

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