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 :

Problème avec une boucle fornext [XL-365]


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    autre
    Inscrit en
    Décembre 2019
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : autre

    Informations forums :
    Inscription : Décembre 2019
    Messages : 23
    Par défaut Problème avec une boucle fornext
    Bonsoir,

    J'aimerais remplir une colonne avec des nombres décroissants Nom : ordre.PNG
Affichages : 135
Taille : 3,1 Ko.

    J'utilise la boucle suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For toto = nbvirole To 1 Step -1
            Cells(toto * 3 - 1, 1).Value = "V" & toto
        Next toto
    nbvirole=7

    Mais par je ne sais quel sortilège, j'obtiens le résultat suivantNom : pas dans l'ordre.PNG
Affichages : 130
Taille : 4,3 Ko

    Si quelqu'un pouvait m'aiguiller, ça serait un beau cadeau de Noël!

    Bon réveillon

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 054
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 054
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Il n'y a aucun sortilège.
    Dans ta procédure Toto représente la ligne où tu écris la valeur donc il commence à la ligne Toto * 3 - 1 soit si Toto = 10 pour commencer la boucle (valeur de la variable nbvirole), il va écrire à la ligne 29 la valeur "V 10"
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre averti
    Homme Profil pro
    autre
    Inscrit en
    Décembre 2019
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : autre

    Informations forums :
    Inscription : Décembre 2019
    Messages : 23
    Par défaut
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,
    Il n'y a aucun sortilège.
    Dans ta procédure Toto représente la ligne où tu écris la valeur donc il commence à la ligne Toto * 3 - 1 soit si Toto = 10 pour commencer la boucle (valeur de la variable nbvirole), il va écrire à la ligne 29 la valeur "V 10"
    Merci de ta réponse
    Je ne suis pas sûr de comprendre.

    Si je décortique la boucle j'ai:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for toto = 7
        Cells(20, 1). Value = V & 7
    Next
     
    For toto = 6
        Cells(17, 1). Value = V & 6
    Next
    Et ainsi de suite. Pourquoi la boucle ne part-elle pas de 7 vers 1?

    EDIT: je viens de voir la bêtise que j'ai écrit. Je comprends en fait.

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 054
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 054
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Mais la boucle part bien de 7 vers 1 mais tu écris à partir de la ligne 7 vers 1 donc tu as l'impression qu'il n'y a pas d'incrémentation négative.
    Exécute la procédure pas à pas (touche F8) et tu verras
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #5
    Membre averti
    Homme Profil pro
    autre
    Inscrit en
    Décembre 2019
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : autre

    Informations forums :
    Inscription : Décembre 2019
    Messages : 23
    Par défaut
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,
    Mais la boucle part bien de 7 vers 1 mais tu écris à partir de la ligne 7 vers 1 donc tu as l'impression qu'il n'y a pas d'incrémentation négative.
    Exécute la procédure pas à pas (touche F8) et tu verras
    J'ai vu ma bêtise en l'écrivant. J'ai bien compris le mécanisme à l'oeuvre pour toto. Par contre je n'arrive vraiment pas voir comment je peux avoir l'ordre de chiffres qui me convient. Je ne veux pas forcément une réponse toute faite, mais quelle piste devrais-je explorer? La définition d'une deuxième variable et donc d'une deuxième boucle?

  6. #6
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 054
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 054
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Il ne faut pas deux boucles. Ce n'est plus de l'informatique mais de l'arithmétique
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub t()
      Dim Row As Long
      Dim MaxRow As Long
      MaxRow = 20
      For Row = 1 To MaxRow
        Debug.Print Row & " v " & MaxRow - Row + 1
      Next
    End Sub
    A toi de l'adapter pour écrire toutes les trois lignes
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  7. #7
    Membre averti
    Homme Profil pro
    autre
    Inscrit en
    Décembre 2019
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : autre

    Informations forums :
    Inscription : Décembre 2019
    Messages : 23
    Par défaut
    Ah oui, l'arithmétique n'est pas mon fort. J'ai réussi en tous cas. Merci à toi et bon réveillon.

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

Discussions similaires

  1. Problème avec une boucle
    Par bf491499 dans le forum VB.NET
    Réponses: 1
    Dernier message: 16/03/2007, 08h35
  2. Problème avec une boucle
    Par sissi25 dans le forum Langage
    Réponses: 7
    Dernier message: 22/02/2007, 00h40
  3. problème avec une boucle
    Par mars315 dans le forum Langage
    Réponses: 14
    Dernier message: 25/11/2006, 09h39
  4. Problème avec une boucle for
    Par cisse18 dans le forum Général JavaScript
    Réponses: 20
    Dernier message: 29/03/2006, 17h50
  5. [MySQL] Problème avec une boucle
    Par yayacameleon dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 09/03/2006, 10h53

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