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 :

lenteur execution macro


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Avril 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Avril 2014
    Messages : 5
    Par défaut lenteur execution macro
    Bonjour à Tous

    je rencontre une énorme lenteur lors de l'exécution de ma macro qui pourtant, n'est pas si compliqué que ça.

    De plus excel plante parfois après l'exécution de la macro

    Est-ce que quelqu'un sait de quoi ça vient ??

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
     
    Sub Macro1()
    '
    ' Macro1 Macro
    '
     
        Dim I As Integer
        I = Feuil1.Range("a1").End(xlDown).Row
        nbcel = 0
        nbcel1 = 0
     
    ' effacement des ancienne données
     
        Sheets("Rapport générer").Select
        Range("A20").Select
        Range(Selection, Selection.End(xlToRight)).Select
        Range(Selection, Selection.End(xlDown)).Select
        Selection.Delete Shift:=xlToLeft
     
     
    ' Copie tableau de la boite noire
     
        Sheets("Feuil1").Select
        Range("A1").Select
        Range(Selection, Selection.End(xlToRight)).Select
        Range(Selection, Selection.End(xlDown)).Select
        Selection.Copy
        Sheets("Rapport générer").Select
        Range("A20").Select
        ActiveSheet.Paste
        Range("A20").Select
     
    ' Calcul de l'offset horraire avec fusionnage celulle
     
     
     
     
    For Each cel In Range("a20:a" & I + 20)
     
    If cel <> "" Then
    nbcel1 = nbcel + 20
    Range(Cells(nbcel1, 2), Cells(nbcel1, 5)).Merge
    Range("A" & nbcel1).Select
    nbcel = nbcel + 1
    ActiveCell.Formula = "=Feuil1!A" & nbcel & " - Feuil1!$F$3"
     
    End If
     
    Next cel
     
    ' Cadrillage Celulle
     
    Range("A20").Select
        Range(Selection, Selection.End(xlToRight)).Select
        Range(Selection, Selection.End(xlDown)).Select
        Selection.Borders(xlDiagonalDown).LineStyle = xlNone
        Selection.Borders(xlDiagonalUp).LineStyle = xlNone
        With Selection.Borders(xlEdgeLeft)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        With Selection.Borders(xlEdgeTop)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        With Selection.Borders(xlEdgeBottom)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        With Selection.Borders(xlEdgeRight)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        With Selection.Borders(xlInsideVertical)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        With Selection.Borders(xlInsideHorizontal)
            .LineStyle = xlContinuous
            .ColorIndex = 0
            .TintAndShade = 0
            .Weight = xlThin
        End With
        Range("H27").Select
     
     
     
    End Sub

  2. #2
    Membre très actif
    Homme Profil pro
    Auto entrepreneur
    Inscrit en
    Décembre 2021
    Messages
    387
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Auto entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2021
    Messages : 387
    Par défaut
    Citation Envoyé par Irish10 Voir le message
    Bonjour,

    C'est sans doute votre formule en ligne 45 qui ralentit le code, sans compter les "select".
    Vous pourriez déjà neutraliser le calcul des formules et le rafraichissement de l'écran pendant la procédure et remettre les paramètres à la fin.

    Nb : Pour la sélection des dernière lignes et colonnes, j'utilise plutôt XlUp et XlToLeft, sinon vous risquez de ne pas prendre toutes les données en cas de cellules vides.

    Sinon, il vous faut expliquer un peu plus les conditions dans lesquelles Excel plante. Une cause possible lorsque vous réalisez les bordures. Il faut vous assurer que le nombre des cellules en colonnes et en lignes soit supérieur à 1 pour les bordures intérieures verticales et horizontales, sachant que vous en fusionnez un certain nombre. Ne connaissant pas votre fichier, difficile de savoir.

    Votre code mériterait d'être simplifié.

    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
     
     
        With Application
             .ScreenUpdating = False
             .Calculation = xlCalculationManual
        End With
     
     
       ' Suite du code
     
     
     
        With Application
             .ScreenUpdating = True
             .Calculation = xlCalculationAutomatic
        End With

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut

    Une macro de +/- 100 lignes n'a pas de sens. Il est largement préférable de scinder votre code en fonctions qui n'ont qu'une seule responsabilité. Ca vous permet de tester chaque fonction indépendamment des autres, notamment pour voir celle qui prend du temps.



    Citation Envoyé par E KERGRESSE Voir le message
    [...]Vous pourriez déjà neutraliser le calcul des formules[...]
    Attention que passer en calcul manuel sans gestion d'erreur est une hérésie sans nom. Si votre code plante, vous restez en manuel, ce qui est potentiellement mortifère.

    Règle de base: On ne modifie JAMAIS une option d'Excel sans la gestion d'erreur qui va avec, en plaçant encore la gestion d'erreur au bon endroit.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Note pour le moinsseur: Il serait utile d'apprendre les bases de la programmation avant de voter -1, et de comprendre un commentaire.

    Avec un Application.Calculation = xlCalculationManual non englobé dans une gestion d'erreur, on a un gros souci en cas de plantage ou de Exit Sub, puisque le calcul reste en manuel.

    Avec un Application.Calculation = xlCalculationAutomatic en fin de macro, on n'est pas certain de remettre l'application dans l'état dans lequel elle se trouvait, puisqu'elle pourrait être en calcul manuel ou en semi-automatique juste avant le démarrage de la macro. Normalement, on doit mémoriser l'état du mode de calcul avant de le passer en manuel, puis le remettre dans cet état en fin de macro sur gestion d'erreur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Test()
      Dim CalculationMode As XlCalculation
     
      On Error GoTo Catch
      CalculationMode = Application.Calculation
      Application.Calculation = xlCalculationManual
      ...
      ...
      ...
     
    Catch:
      Application.Calculation = CalculationMode
    End Sub
    Avant de moinsser comme un débile, il faut comprendre la portée et les conséquences de son code. Sans cela, on risque de passer pour un amateur qui pisse du code sans le comprendre. Mais c'est sans doute plus simple de cliquer sur -1 sans effort intellectuel.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

Discussions similaires

  1. [XL-2010] Lenteur execution macro
    Par anthony77350 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 16/03/2017, 09h10
  2. [XL-2007] Lenteur execution macros
    Par C15nantes dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 29/12/2015, 12h07
  3. [XL-2007] Lenteur execution macro
    Par francky62000 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 10/12/2011, 19h25
  4. vb6 ou vba - lenteur execution macro sur excel 2007
    Par Enigme dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 26/03/2010, 13h50
  5. Réponses: 4
    Dernier message: 19/05/2005, 11h51

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