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 :

Durée macro interminable ? [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut Durée macro interminable ?
    Bjr,

    J'ai mis dans Worbook / Before Open 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
    Private Sub Workbook_Open()
     
    'Défiltre toutes les colonnes
     
    Sheets("Feuil1").Select
    Rows("1:1").Select
        Selection.AutoFilter
        Selection.AutoFilter
    For i = 1 To 256
    Selection.AutoFilter Field:=i
    Next i
    End Sub
    Mon fichier Excel etant assez volumineux (10Mo), j'ai une feuille (Feuil1) où mes colonnes vont jusqu'à IV sur 150 Lignes.

    Il arrive souvent que je fasse un tri sur une ou plusieurs colonnes.
    C'est pour celà qu'au démarrage, toutes les colonnes de cette feuille sont défiltrées. Il faut également savoir que dans cette feuille, beaucoup de colonnes font références à d'autres feuilles par le biais de formule de ce type :

    {=SI(ESTERREUR(INDEX(Spot!$L$2:$L$999;EQUIV(1;(Spot!$A$2:$A$999=$A6)*(Spot!$I$2:$I$999=BM$1);0)));"";INDEX(Spot!$L$2:$L$999;EQUIV(1;(Spot!$A$2:$A$999=$A6)*(Spot!$I$2:$I$999=BM$1);0)))}

    Le problème est que celà prend (chrono en main) 17 mn.

    Y aurait il une solution pour pallier à cette attente ?

    Cordialement.

  2. #2
    Expert confirmé Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Par défaut
    Bonjour,

    Pour acceler le code, désactive l'affichage et les calculs

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
     
    ...
     
     
    Application.ScreenUpdating = True
    Application.Calculation = xlCalculationAutomatic

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 105
    Par défaut
    Bonjour,

    Il me semble que malheureusement, il n'y a pas beaucoup de moyens d'accélérer ton code.

    Néanmoins peut-être que en désactivant le calcul automatique et en le remettant à la fin de ta macro tu pourrais gagner du temps
    voici l'instruction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    application.Calculation = xlCalculationManual
    'ton code
    application.Calculation = xlCalculationAutomatic
    de même il est possible de gagner du temps avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.screenUpdating = False
    'ton code
    Application.screenUpdating = True
    mais sinon je ne vois pas comment faire plus...

  4. #4
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Merci à vous 2

    çà prend environ 10 secondes maintenant

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

Discussions similaires

  1. [XL-2010] modifs de cellules protégées et durée de la macro
    Par glooping dans le forum Excel
    Réponses: 5
    Dernier message: 07/05/2015, 13h02
  2. [XL-2013] Affichage des étapes d'une macro de longue durée + Barre de progression si possible
    Par Henri1830 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 11/12/2014, 21h07
  3. Réponses: 4
    Dernier message: 14/12/2009, 13h53
  4. Qu'est-ce qu'une macro ?
    Par karli dans le forum Assembleur
    Réponses: 2
    Dernier message: 01/09/2002, 04h38
  5. Réponses: 2
    Dernier message: 22/07/2002, 13h13

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