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 :

incompréhension de macro


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2008
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 53
    Par défaut incompréhension de macro
    Bonjour, je suis en train de me former sur VBA actuellement (en autodidacte pas facile)

    J'ai recu il y a quelque temps ce morceau de macro:
    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
     
     
    'CREATION DES ONGLETS
        Dim CelTest As Range
        Dim SheetTest As Worksheet
        With Worksheets(1)
            For Each CelTest In .Range(.Cells(Rows.Count, "G").End(xlUp), .Range("G1"))
                If CelTest.Value <> "" Then
                    For Each SheetTest In Worksheets
                        If SheetTest.Name = CelTest.Value Then
                        .Rows(CelTest.Row).Copy Sheets(CelTest.Value).Cells(Rows.Count, "G").End(xlUp).Offset(1, -6)
            GoTo apres
                        End If
                    Next
                    Sheets.Add after:=Sheets(Sheets.Count)
                    Sheets(Sheets.Count).Name = CelTest.Value
                    .Rows(CelTest.Row).Copy Sheets(CelTest.Value).Cells(Rows.Count, "G").End(xlUp).Offset(1, -6)
    apres:
                End If
            Next
        End With
    Ceci fonctionne très bien, par contre je ne comprend pas pourquoi il y a un "." avant Range dans "For Each CelTest In .Range(.Cells(Rows.Count, "G").End(xlUp), .Range"

    pouvez-vous m'aider merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Le . au début fait référence à ce qu'il y a dans le With.

    Donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    With Worksheets(1)
      For Each CelTest In .Range(.Cells(Rows.Count, "G").End(xlUp), .Range("G1"))
      ...
    End With
    est l'équivalent de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For Each CelTest In Worksheets(1).Range(Worksheets(1).Cells(Rows.Count, "G").End(xlUp), Worksheets(1).Range("G1"))

  3. #3
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    déclare CelTest en tant que range (ici une cellule)
    Celtest devient un objet qui évite de répéter Cells(NoLigne, NoCol)
    De la même manière, on aurait pu écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim FL1 As Worksheet
    Dim Plage As Range
    Dim CelTest As Range
    Dim SheetTest As Worksheet
        Set FL1 = Worksheets(1)
        With FL1
            Set Plage = .Range(.Cells(.Rows.Count, 7).End(xlUp), .Range("G1"))
            For Each CelTest In Plage
                If CelTest <> "" Then
    etc. Ici on utilise l'objet FL1 (la feuille) pour désigner l'objet plage (la plage de cellules) et enfin CelTest (une cellule de la plage que l'on parcourt)
    Tu peux remarquer que Plage, instancié "with" FL1, dispense d'avoir à utiliser le point dans la ligne
    For Each CelTest In Plage
    Placé avant "With FL1", il eut fallu écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set Plage = FL1.Range(FL1.Cells(FL1.Rows.Count, 7).End(xlUp), FL1.Range("G1"))
    Cette manière de programmer condence le code et facilite une relecture
    Bonne soirée

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Février 2008
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 53
    Par défaut
    merci beaucoup c'est déja plus lisible

    A bientôt

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

Discussions similaires

  1. [XL-2010] Erreur incompréhensible dans ma Macro (VBA) à l'aide!
    Par Wendy_26 dans le forum Macros et VBA Excel
    Réponses: 16
    Dernier message: 04/09/2014, 11h40
  2. Macro complémentaire incompréhensible
    Par theshark85 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 26/11/2008, 14h22
  3. [VBA-E] [Excel] Lancer une macro à une heure donnée
    Par Lysis dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 16/10/2002, 12h15
  4. Qu'est-ce qu'une macro ?
    Par karli dans le forum Assembleur
    Réponses: 2
    Dernier message: 01/09/2002, 03h38
  5. Réponses: 2
    Dernier message: 22/07/2002, 12h13

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