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 :

Optimiser une boucle For each .. next [XL-2013]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut Optimiser une boucle For each .. next
    Bonjour,

    Je dois remettre un onglet comportant un nombre important de cellule en fonction de leur couleur. Il ne s'agit pas d'une plage fixe malheureusement.

    Le code que j'ai trouvé prend énormément de temps :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
       Sheets("E3_Affectation_CI&PD").Select
    For Each Cellule In Range("g8:BZ329")
             If ActiveCell.Interior.ColorIndex = 36 Then
             ActiveCell.Value = ""
    End If
    Next
     
    End Sub
    Auriez-vous une autre astuce pour accélérer le traitement?

    J'ai pensé à mettre une autre condition : si la valeur de la cellule est vide. Mais la macro ne fait plus rien...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
        Sheets("E3_Affectation_CI&PD").Select
    For Each Cellule In Range("g8:BZ329")
             If ActiveCell.Interior.ColorIndex = 36 And ActiveCell.Value <> "" Then
     
             ActiveCell.Value = ""
    End If
    Next
     
    End Sub
    Merci par avance pour votre aide

  2. #2
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour,
    déjà, au départ, ton code devrait être
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Dim Cellule As Range
    With Sheets("E3_Affectation_CI&PD")
       For Each Cellule In .Range("g8:BZ329")
         If Cellule.Interior.ColorIndex = 36 Then
           Cellule.Value = ""
         End If
      Next Cellule
    End With
    Pour la rapidité, je vais regarder, sans garantie
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    Merci!

  4. #4
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    en respectant tes limites, essayes ce code maxi 1 seconde
    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
    Sub couleurs()
    Dim Cellule As Range, x As Long, y As Long
    Dim Tb(), tb1
    With Sheets("E3_Affectation_CI&PD")
      tb1 = .Range("g8:BZ329")
      ReDim Tb(1 To UBound(tb1, 1), 1 To UBound(tb1, 2))
      For x = 7 To 72
        For y = 8 To 329
          Tb(y - 7, x - 6) = .Cells(y, x).Interior.ColorIndex
        Next y
      Next x
      For x = 1 To UBound(tb1, 2)
        For y = 1 To UBound(tb1, 1)
          If Tb(y, x) = 36 Then tb1(y, x) = ""
        Next y
      Next x
      .Range("G8").Resize(UBound(tb1, 1), UBound(tb1, 2)) = tb1
    End With
    End Sub
    dis-moi quoi car vite fait

    Edit :code modifié (un peu plus logique)
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    Au top ça marche impec merci infiniment!

  6. #6
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    En fait cela marche bien mais la fonction efface les formules de mon tableau sans les recopier. Les formules sont copiées en dur...
    Est-ce que tu aurais une parade casefayere? Merci beaucoup

  7. #7
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour, je ne savais pas qu'il y avais des formules donc, il faudrait passer par une boucle pour remplir "tbl",comme "tb", conclusion temps de traitement légèrement allongé, mais la parade consiste à ne prendre dans "'tbl" que la plage sans les formules, pour ça il me faudrait des indications supplémentaires, (ou sont les formules, etc.)
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  8. #8
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    LE problème est qu'il y a des formules à plusieurs endroits assez variables...mais avec des couleurs identifiées.
    Est-ce qu'il est possible de garder les formules en fonction de certaines couleurs ?

    Il s'agit des couleurs 15 et 25.


    Merci beaucoup

  9. #9
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    là, tu compliques le travail, peux-tu envoyer un fichier bidon, je regarderai sans promesse de résultat, à moins que quelqu'un plus aguerri puisse te donner une bonne piste
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  10. #10
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    Le voici merci.

    J'ai laissé juste l'onglet en question. La macro correspondante est "effacer" ou Module 3 dans le code.

    Les formules ont sautées mais en gros ce sont les celulles bleues foncées et grises

    Merci ça serait vraiment top!!
    Fichiers attachés Fichiers attachés

  11. #11
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Si tu gardes toutes les formules, la solution est plus simple que ce que j'aurais pu croire
    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
    Option Explicit'je me suis permi
    Sub Effacer()
    Dim Cellule As Range, x As Long, y As Long
    Dim Tb(), Tb1, Dcel As Long
     
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
    'msgbox d'alerte
     
    Dim msgValue
    msgValue = MsgBox("Attention, vous allez effacer toutes les données saisies", vbOKCancel + vbExclamation, "ATTENTION !")
    If msgValue = vbCancel Then
      Exit Sub
    End If
     
    'Remise à zéro de l'onglet E3_Affectation_CI&PD
     
    With Sheets("E3_Affectation_CI&PD")
    Dcel = .Range("F" & .Rows.Count).End(xlUp).Row
      Tb1 = .Range("G8:AG" & Dcel).Formula
      ReDim Tb(1 To UBound(Tb1, 1), 1 To UBound(Tb1, 2))
      For x = 7 To 33
        For y = 8 To Dcel
          Tb(y - 7, x - 6) = .Cells(y, x).Interior.ColorIndex
        Next y
      Next x
      For x = 1 To UBound(Tb1, 2)
        For y = 1 To UBound(Tb1, 1)
          If Tb(y, x) = 36 Then Tb1(y, x) = ""
        Next y
      Next x
     .Range("G8").Resize(UBound(Tb1, 1), UBound(Tb1, 2)) = Tb1
    End With
    Application.Calculation = xlCalculationAutomatic
    Application.ScreenUpdating = True
     
    End Sub
    essayes et dis-moi
    Nom : option.JPG
Affichages : 482
Taille : 40,4 Ko
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  12. #12
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    Bonjour et merci beaucoup pour ta réponse, je n'ai pu essayer que ce matin.

    Le code me renvoi une erreur sur la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dcel = .Range("F" & .rows.Count).End(xlUp).row
    Il indique une "invalid or unqualified reference" sur .rows.

    C'est une erreur de déclaration de variable?

    Merci encore pour ton aide précieuse

  13. #13
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dcel = .Range("F" & .rows.Count).End(xlUp).row
    la syntaxe est correcte d'autant qu'avant on spécifie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    With Sheets("E3_Affectation_CI&PD")
    de plus Dcel est bien déclaré en long, vérifie le nom de ta feuille et ce que contient la colonne F, j'avais vérifié mon code donc quelque-chose a du changer entre temps
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  14. #14
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    94
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Août 2011
    Messages : 94
    Points : 62
    Points
    62
    Par défaut
    Yes c'est bon au temps pour moi j'avais effacé cette ligne par erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    With Sheets("E3_Affectation_CI&PD")
    Je te remercie vivement pour tout

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

Discussions similaires

  1. [XL-2007] Copier coller plage de cellules dans une boucle For Each..Next
    Par JulieD33 dans le forum Excel
    Réponses: 3
    Dernier message: 02/03/2015, 11h19
  2. Lenteur d'une boucle For each next
    Par Val2000 dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 27/05/2013, 11h41
  3. Optimiser une boucle For Each
    Par zaghi dans le forum VB.NET
    Réponses: 14
    Dernier message: 21/06/2012, 11h19
  4. boucle for each next : sauter une valeur
    Par scavenger dans le forum VBScript
    Réponses: 1
    Dernier message: 18/02/2009, 10h15
  5. [VBA-E]PB sur une boucle for each next
    Par rond24 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 31/07/2006, 15h47

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