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 :

Exécution très lente lorsqu'un autre fichier est ouvert


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
    Juin 2010
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 16
    Par défaut Exécution très lente lorsqu'un autre fichier est ouvert
    Bonjour bonjour !

    J'ai un soucis qui devient vraiment embêtant, et bien que je ne sois pas obligé de le résoudre, il faudrait au moins que j'en comprenne bien la cause...

    Voilà ce qui se passe :
    J'ai créé un fichier Excel, avec des macros, tout ça tout ça... Ce fichier fonctionne très bien (et rapidement) en temps normal.

    Là où il y a un soucis, c'est que lorsqu'un autre fichier Excel est ouvert (dans la même fenêtre), ça devient horriblement lent ! Même s'il n'y a aucune interaction entre les deux fichiers...
    Ça ne le fait pas si j'ouvre n'importe quel fichier Excel... le fichier Excel que j'ouvre et qui "ralenti" le tout est un fichier qu'on me fourni (je ne le connais donc pas vraiment) et qui pèse plus de 7 Mo... Je pense (pour le moment) que c'est le volume trop important de ce fichier qui est la cause du problème.

    Par exemple, lorsque mon fichier est bien remplit :
    - En temps normal, la mise à jour d'une des feuilles de mon fichier peut prendre 10 secondes (je prend vraiment l'exemple d'un fichier bien remplit ><)
    - Avec le fichier qu'on me fournit ouvert en même temps, ça prend... bah je me suis arrêté de regarder après 10 minutes... (mais ça se fini bien au bout d'un moment, après pause café et tout...)

    Avec un fichier moins remplit, la mise à jour de la feuille en temps normal est instantanée en temps normal, et prend environ 10 secondes avec l'autre fichier ouvert...

    Bon vous pensez bien que si j'avais le choix, je fermerais le fichier fourni le temps de l'exécution :p, mais je ne peux pas car il y aura plus tard des interactions entre les fichiers...


    Donc ce que je voudrais savoir, c'est (si vous le savez) d'où vient ce ralentissement ? (Je pense que c'est le poids du fichier fourni, mas en réalité rien ne me dit que je ne me trompe pas) Ça m'intrigue pas mal car je trouve "bizarre" qu'un simple fichier ouvert à côté du mien puisse le ralentir ><

    Et au cas où (mais alors là je crois que je rêve ><), même si je ne suis pas obligé de résoudre le soucis... si quelqu'un connaissait une solutions ? ^^'

    Voilà, merci d'avance ^^
    Bonne journée.

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Salut,
    ton second fichier est-il avec des formules ?

    Si tu travailles dans la meme occurence d'Excel, a chaque modification des valeurs d'une cellule, tu enclenches le rafraichissement des calculs...

    Les pistes a explorer :
    - supprimer le recalcul auitomatic
    - travailler dans une occurence d'Excel avec un seul fichier
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 16
    Par défaut
    Bonjour et merci déjà ^^

    Le fichier Excel qu'on me fourni contient bien des formules... qui doivent en effet se recalculer à chaque fois tant que je suis dans la même fenêtre Excel...
    Je n'y avais pas du tout pensé, et si je regarde un peu mieux il n'y en a pas qu'un peu des formules...

    - travailler dans une occurrence d'Excel avec un seul fichier
    Comme je l'ai dis : tant que je ne dois pas faire de lien entre les deux c'est possible, mais je sais que je vais devoir en faire donc cette solution ne serait pas adaptée chez moi ^^'

    - supprimer le recalcul automatique
    Je ne pourrais pas demander à tous les utilisateurs de faire ça : ils oublieraient de le remettre, ils ne sauraient pas comment faire, ect...
    Par contre il y a sans doute un moyen de le désactiver au début des procédures, et de le réactiver à la fin avec une fonction VBA... Je vais chercher par là ^^ (si ça existe, ça doit être un truc on ne peut plus simple)


    Hé bah merci beaucoup, tu m'as sans doute même apporté la solution à mon problème .

    J'éditerais ce message si c'est bon pour donné la fonction.
    En attendant, je connais de toute façon la cause, donc un clic sur "résolut" ^^

  4. #4
    Membre Expert Avatar de mayekeul
    Inscrit en
    Août 2005
    Messages
    1 369
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 1 369
    Par défaut
    bonjour,

    juste pour info

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    'pour désactiver la calculation automatique
    Application.Calculation = xlCalculationManual
    'pour la remettre
    Application.Calculation = xlCalculationAutomatic

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 16
    Par défaut
    Ah bah voilà, je revenais pour éditer >< Plus besoin apparemment ^^

    Ça fonctionne super, plus de ralentissement, il va y avoir des heureux ^^

    Merci beaucoup !

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 01/07/2010, 18h05
  2. [WD-2007] Exécution très lente des macros
    Par bibendum7302 dans le forum VBA Word
    Réponses: 10
    Dernier message: 22/06/2009, 12h27
  3. Réponses: 4
    Dernier message: 12/06/2008, 12h37
  4. [Utilisation] Keyword sur un fichier, également MAJ quand un autre fichier est modifié
    Par minimarch76 dans le forum Subversion
    Réponses: 0
    Dernier message: 17/01/2008, 11h14
  5. Temps d'exécution très lent
    Par michelin123 dans le forum MATLAB
    Réponses: 14
    Dernier message: 20/11/2007, 15h17

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