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 excel) mise en boucle


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de CIBOOX
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    194
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 194
    Par défaut (vba excel) mise en boucle
    bonjour le forum
    j'aimerai mettre en boucle une partie de mon code afin de l'alleger
    voila je dois compter le nombre de trajet de trois ville ( paris 7eme,paris 16 eme et paris 13eme ) et ceux ci selon les quatres mode de transport utilisé ( ratp,a pied ; en vehicule personnel ou fonctionnel) pour ce faire j'utilise le code suivant
    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
    a = 0
    b = 0
    c = 0
    d = 0
    e = 0
    L = 2
    ville = paris7M
     
    With Worksheets("bd")
    For I = 1 To .Range("a65536").End(xlUp).Row
    If .Range("F" & I) = "ville" And .Range("G" & I) = "RATP" Then a = a + 1
    If .Range("F" & I) = "ville" And .Range("G" & I) = "pied" Then b = b + 1
    If .Range("F" & I) = "ville" And .Range("G" & I) = "vlfonctionnel" Then c = c + 1
    If .Range("F" & I) = "ville" And .Range("G" & I) = " vlPersonel" Then d = d + 1
    If .Range("F" & I) = "ville" And .Range("G" & I) <> "" Then e = e + 1
     
    Next I
    .Range("M" & L) = a
    .Range("N" & L) = b
    .Range("O" & L) = c
    .Range("P" & L) = d
    .Range("Q" & L) = e
    maintenant j'aimerai installer une boucle
    de telle maniere a ce que une fois qu'il a fait ville = paris 7m il me colle la premiere valeur dans m2 et ainsi de suite jusqu'a q2
    puis ville devient paris 13 et me colle les valeurs la ligne suivante c'est a dire dans m3 et ainsi de suite jusqu'a q3
    et enfin ville= paris16m et les valeurs une ligne en dessous ( de m4 à q4 )

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2003
    Messages : 52
    Par défaut
    Salut

    Idée : Déclarer un tableau pour tes villes que tu parcours avec un indice.

    a+

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2003
    Messages : 52
    Par défaut
    un truc dans ce genre :
    (Pas testé)
    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
    30
    31
    32
    33
    34
    35
    36
     
    Sub transport()
    Dim tabVilles As Variant
    Dim ville as String
    Dim i as Long
    Dim j As Byte
     
    tabVilles = Array("paris7M", "paris16M", "paris13M")
     
    L = 2
     
    For j = 0 To UBound(tabVilles) - 1
    ville = tabVilles(j)
        a = 0
        b = 0
        c = 0
        d = 0
        e = 0
        With Worksheets("bd")
            For i = 1 To .Range("a65536").End(xlUp).Row
                If .Range("F" & i) = ville And .Range("G" & i) = "RATP" Then a = a + 1
                If .Range("F" & i) = ville And .Range("G" & i) = "pied" Then b = b + 1
                If .Range("F" & i) = ville And .Range("G" & i) = "vlfonctionnel" Then c = c + 1
                If .Range("F" & i) = ville And .Range("G" & i) = " vlPersonel" Then d = d + 1
                If .Range("F" & i) = ville And .Range("G" & i) <> "" Then e = e + 1
            Next i
            .Range("M" & L) = a
            .Range("N" & L) = b
            .Range("O" & L) = c
            .Range("P" & L) = d
            .Range("Q" & L) = e
            L = L + 1
        End With
    Next j
     
    End Sub

    ville étant une variable il ne faut pas de guillemets...

  4. #4
    Membre confirmé Avatar de CIBOOX
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    194
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 194
    Par défaut
    BONJOUR choucks
    J'ai teste ton code et il me met que deux lignes m2:q2 et m3:q3
    avec des 0 dans toute les cellules.
    merci je ne connais pas le truc pour a ne pas faire ( "") pour la ville

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2003
    Messages : 52
    Par défaut
    Citation Envoyé par CIBOOX
    BONJOUR choucks
    J'ai teste ton code et il me met que deux lignes m2:q2 et m3:q3
    avec des 0 dans toute les cellules.
    merci je ne connais pas le truc pour a ne pas faier ( "") pour la ville
    Supprimes le -1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For j = 0 To UBound(tabVilles) - 1
    Et si ça renvoie que des 0 c'est que les conditions ne sont jamais vraies. Quelle est l'orthographe du nom des villes dans la feuille exemple pour le 7ème: est-ce paris 7eme, paris7M ou paris 7m ?

    A toi de saisir l'orthographe adequat dans la déclaration du tableau.

  6. #6
    Membre confirmé Avatar de CIBOOX
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    194
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 194
    Par défaut
    le ça marche

    meme apres verification des nom des villes j'ai des lignes avec 0

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

Discussions similaires

  1. VBA/Excel "Mise en forme de texte dans des cellules"
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 06/03/2007, 16h20
  2. [VBA-Excel]Mise à jour des liaisons powerpoint
    Par Mando dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 08/12/2006, 22h51
  3. [VBA-Excel] Mise en forme d'un classeur
    Par snooopy007 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 25/07/2006, 18h37
  4. [VBA][Excel] mise en forme conditionnelle
    Par titflocon dans le forum Access
    Réponses: 9
    Dernier message: 19/12/2005, 10h13
  5. [VBA][EXCEL] Mise à jour de TCD en macro
    Par Scuriolus dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 07/12/2005, 13h30

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