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 :

macro trop lente


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juin 2011
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juin 2011
    Messages : 80
    Par défaut macro trop lente
    Bonjour,

    J'ai une macro qui permet le remplacement de tous les #ERR, #NOM, etc... par des X. Mais au vu du nombre de cellule (parfois plus de 30 000), cela prend trop de temps, surtout que c'est à la suite d'une mise à jour sur toute ces celulles. Un exemple de temps est de 3min30 pour tout avec 1min juste pour les X, donc trop long.
    Y-a-t-il moyen de raccourcir? Et si oui comment?
    Voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Application.ScreenUpdating = False
        Application.DisplayAlerts = False
        For Each cel In ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas)
            oldCel = Mid(cel.FormulaR1C1, 2, Len(cel.FormulaR1C1) - 1)
            cel.FormulaR1C1 = "=IF(ISERROR(" & oldCel & "),""X""," & oldCel & ")"
        Next cel
    Merci d'avance pour toutes vos réponses toujours très constructives.
    Tioch

  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,

    Je vois que dans ta macro tu ne bascule pas en calcul manuel, il y a donc des chances pour les calculs se fassent a chaque insertion de formule

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    application.Calculation=xlCalculationManual

  3. #3
    Membre confirmé
    Inscrit en
    Juin 2011
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juin 2011
    Messages : 80
    Par défaut
    Tout d'abord merci pour ta réponse si rapide.
    Mais comment je le mets dans la macro?
    Je dois pas le remettre en automatique après?

    Merci bien

  4. #4
    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
    Comme cela
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
        Application.DisplayAlerts = False
        For Each cel In ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas)
            oldCel = Mid(cel.FormulaR1C1, 2, Len(cel.FormulaR1C1) - 1)
            cel.FormulaR1C1 = "=IF(ISERROR(" & oldCel & "),""X""," & oldCel & ")"
        Next cel
     
    Application.Calculation = xlCalculationAutomatic

  5. #5
    Membre confirmé
    Inscrit en
    Juin 2011
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juin 2011
    Messages : 80
    Par défaut
    Merci Jérome,
    Je vais faire des tests et je reviens.

Discussions similaires

  1. [XL-2007] Solutions pour macros trop lente
    Par pasterlouis dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 28/08/2013, 12h04
  2. [XL-2007] Boucles for imbriquées, macro trop lente
    Par Jambonpurée dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 13/06/2011, 18h25
  3. [XL-2003] Macro boucle for next trop lente
    Par sixtm dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/06/2011, 17h08
  4. [XL-2003] Macro qui fonctionne mais c'est trop lent
    Par lululaberlu dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 21/08/2009, 12h02
  5. [XL-2007] macros trop lentes (85 onglets)
    Par dodo28 dans le forum Macros et VBA Excel
    Réponses: 36
    Dernier message: 16/04/2009, 21h20

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