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 :

Probleme / For sans Next


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2018
    Messages : 30
    Points : 18
    Points
    18
    Par défaut Probleme / For sans Next
    Bonjour, amis développeurs.

    Je rencontre aujourd'hui un problème dans mon code.

    En effet, une erreur survient quand je lance ma maccro : "For sans next"

    Quelqu'un pourrait-il m'éclairer ?

    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    Sub kkdu74()
     
    Dim wkb As Workbook
     
    Dim CopCounter As Integer
    CopCounter = 12
    Dim kkCounter As Integer
    kkCounter = 28
     
     
        For CopCounter = 1 To 12
        mensu = ThisWorkbook.Sheets(3).Range("F" & CopCounter).Value
        mensu_wk = Workbooks.Open("F:\Partages\Commun_DRH\Taux de recouvrement\Année 2018\" & mensu)
     
        For kkCounter = 1 To 28
        pole = ThisWorkbook.Sheets(3).Range("G" & kkCounter).Value
     
        DirFile = ("F:\Partages\Commun_DRH\Taux de recouvrement\Evolution\2018\" & pole)
        If Dir(DirFile) = "" Then
        Set wkb = Workbooks.Add
        ActiveWorkbook.SaveAs Filename = pole & ".xls"
        With Range("A1:C28") 'Début de l'instruction avec : WITH
                ActiveSheet.Select
        Selection.PasteSpecial Paste = xlPasteValues, Operation = xlNone, SkipBlanks _
            = False, Transpose = False
             .Borders.Value = 1
             .Interior.Color = RGB(174, 240, 194)
             With .Font
                 .Size = 12
                 .name = "Arial"
                 .Bold = False
             End With
         End With
         Else
         Workbooks.Open ("F:\Partages\Commun_DRH\Taux de recouvrement\Evolution\2018\" & pole)
         With Range("A1:C28") 'Début de l'instruction avec : WITH
                ActiveSheet.Select
         Selection.PasteSpecial Paste = xlPasteValues, Operation = xlNone, SkipBlanks _
            = False, Transpose = False
             .Borders.Value = 1
             .Interior.Color = RGB(174, 240, 194)
             With .Font
                 .Size = 12
                 .name = "Arial"
                 .Bold = False
             End With
          End With
     
            End If
     
        Next
     
    End Sub
    Merci beaucoup !!

  2. #2
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 814
    Points : 2 949
    Points
    2 949
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Lignes 11 et 15 tu inities deux boucles For ...
    Ligne 51 tu en fermes une par l'instruction Next.
    Quid de la seconde?
    Quand décides tu de la fermer?
    Cordialement,
    Franck

  3. #3
    Membre expert
    Avatar de Igloobel
    Homme Profil pro
    Développeur ERP - VBA et Formateur bureautique
    Inscrit en
    Septembre 2005
    Messages
    1 869
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Développeur ERP - VBA et Formateur bureautique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 869
    Points : 3 442
    Points
    3 442
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Ben oui tu as 2 For et un seul Next donc c'est normal

    indente ton code un peu mieux et tu verras ou tu dois mettre ton second Next
    Ils ne savaient pas que c'était impossible ... du coup ils l'ont fait (Mark Twain)

    n'oubliez pas de si les messages vous aide ou sont pertinents et de mettre quand cela est !

  4. #4
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par Igloobel Voir le message
    indente ton code un peu mieux et tu verras ou tu dois mettre ton second Next
    +1
    Je rajouterai qu'il est conseillé (même si ce n'est pas obligatoire) d'indiquer dans le Next le nom de la variable compteur du For To, histoire, justement, de ne pas s'y perdre.
    Lire ça : https://msdn.microsoft.com/fr-fr/VBA...next-statement
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2018
    Messages : 30
    Points : 18
    Points
    18
    Par défaut
    Que suis-je bête ....
    Je pensais que 1 "Next" pouvais s'appliquer à deux "For".
    Merci de votre réponse.

    De plus, j'aimerai savoir si je dois déclarer une variable pour cette ligne de code avec le "For" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     Dim wkb As Workbook
    Dim CopCounter As Integer
      CopCounter = 12
    Dim kkCounter As Integer
      kkCounter = 28
    Dim mensu As String
    Dim mensu_wk As Workbook
     
     
     For CopCounter = 1 To i + 1
        mensu = ThisWorkbook.Sheets(3).Range("F" & CopCounter).Value
        mensu_wk = Workbooks.Open("F:\Partages\Commun_DRH\Taux de recouvrement\Année 2018\" & mensu & ".xls")
    Voilà ma question : J'aimerai que cette partie de mon code, si c'est possible, ouvre le fichier qui à pour nom "mensu" SSI il existe. J'ai commencé avec un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For CopCounter = 1 To 12
    Les fichiers seront bien crée au fur et à mesure.

  6. #6
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Je ne comprends pas pourquoi tu renseignes CopCounter alors que tu n'utilises pas sa valeur avant qu'elle soit modifiée par le For To.

    Par contre, tu ne déclares pas la variable i et tu ne la renseignes pas non plus.
    Donc ton For To risque de ne pas fonctionner comme tu le souhaites.

    Voilà ma question : J'aimerai que cette partie de mon code, si c'est possible, ouvre le fichier qui à pour nom "mensu" SSI il existe.
    Tu peux vérifier l'existence d'un fichier avec la fonction Dir().
    https://msdn.microsoft.com/fr-fr/VBA...s/dir-function
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  7. #7
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2018
    Messages : 30
    Points : 18
    Points
    18
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim i As Integer
     
     
     
      For CopCounter = 1 To i + 1
    Dans ce cas présent, ai-je bien renseigné ma variable i ?
    Ou devrais-je rajouter une ligne comme :
    "i = ?....?"

  8. #8
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par waramere Voir le message
    Dans ce cas présent, ai-je bien renseigné ma variable i ?
    Je te le répète, tu ne peux pas l'avoir bien renseignée puisque tu ne l'as PAS DU TOUT renseignée.

    Ou devrais-je rajouter une ligne comme :
    "i = ?....?"
    Certainement.

    J'ai l'impression que tu confonds compteur et bornes dans ton instruction For To.
    Tu devrais lire ça : http://silkyroad.developpez.com/vba/boucles/
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  9. #9
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2018
    Messages : 30
    Points : 18
    Points
    18
    Par défaut
    Oui mais je comprend pas pourquoi je devrais changé "12" par "i"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        For CopCounter = 1 To 12
        mensu = ThisWorkbook.Sheets(3).Range("F" & CopCounter).Value
        mensu_wk = Workbooks.Open("F:\Partages\Commun_DRH\Taux de recouvrement\Année 2018\" & mensu & ".xls")
    Je veux juste que ma fonction, ouvre le fichier qui porte le nom d'une de mes valeurs dans ma colonne "F" et ainsi de suite.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        mensu_wk = Workbooks.Open("F:\Partages\Commun_DRH\Taux de recouvrement\Année 2018\" & mensu & ".xls")[/
    Mais je sais pas pourquoi cette ligne ne fonctionne pas. Je veux juste que la macro prennent en compte le fichier qu'il y a dans le dossier peut importe le nombre. Qu'il y en ai 12 ou 4 ou 3...

  10. #10
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par waramere Voir le message
    Oui mais je comprend pas pourquoi je devrais changé "12" par "i"
    Moi non plus.

    Mais je sais pas pourquoi cette ligne ne fonctionne pas.
    Déjà, il faudrait que tu expliques un peu ce qui se passe parce que "ne fonctionne pas", c'est plutôt vague comme description de dysfonctionnement.

    Ensuite, dans VBE, mets un point d'arrêt sur la ligne mensu = ... et regarde la valeur de cette variable dans la fenêtre des variables locales.
    Bref, du travail de débugage classique.

    Je veux juste que la macro prennent en compte le fichier qu'il y a dans le dossier peut importe le nombre. Qu'il y en ai 12 ou 4 ou 3...
    Pour faire ça, effectivement, il va falloir faire une borne supérieure variable pour ton For To.
    Mais il faut que ce soit une variable calculée. Tu ne peux pas mettre simplement une variable vide en espérant que VBA détermine sa valeur seul.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  11. #11
    Inactif  

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2012
    Messages
    4 904
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4 904
    Points : 10 168
    Points
    10 168
    Billets dans le blog
    36
    Par défaut
    Ben, c'est vrai, tu as 2 For et un Next.

    Commence par bien implanter l'indentation de ton code, pour avoir les débuts de blocs à égalité avec les fins de blocs imbriqués en retrait dans le bloc qui les contient. Quand tu auras trouvé l'endroit où il faut un next, tu pourras l'ajouter.
    À ma connaissance, le seul personnage qui a été diagnostiqué comme étant allergique au mot effort. c'est Gaston Lagaffe.

    Ô Saint Excel, Grand Dieu de l'Inutile.

    Excel n'a jamais été, n'est pas et ne sera jamais un SGBD, c'est pour cela que Excel s'appelle Excel et ne s'appelle pas Access junior.

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

Discussions similaires

  1. Problème Erreur de compilation "For Sans Next"
    Par lesly94 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 07/07/2015, 09h12
  2. Excel vba : Erreur de compilation for sans next
    Par BENNASR dans le forum Excel
    Réponses: 2
    Dernier message: 26/11/2014, 10h05
  3. probleme avec la fonction for i ..next i
    Par doogybreton dans le forum VBA Access
    Réponses: 18
    Dernier message: 25/01/2008, 01h56
  4. Aide pour For each..... Next
    Par Virgile59 dans le forum Access
    Réponses: 1
    Dernier message: 24/05/2006, 14h34
  5. Probleme formulaire sans doublon...
    Par sentenza dans le forum IHM
    Réponses: 6
    Dernier message: 09/02/2006, 12h29

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