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 du code VBA Très Très lent dans un sens et rapide dans l'autre ? [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    responsable RH
    Inscrit en
    Janvier 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : responsable RH
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2016
    Messages : 28
    Par défaut exécution du code VBA Très Très lent dans un sens et rapide dans l'autre ?
    Bonjour ,
    je suis en train de créer un fichier Excel pour gérer le planning de personnels .
    A ce titre, j'ai créé des 'UserForm' pour faciliter l'utilisation des différentes options :
    -> une option me pose un problème car elle fonctionne très bien dans un sens MAIS elle est très Lente dans le sens inverse, alors qu'elle ne concerne 12 cellules à copier.

    Explication :
    - un bouton 'CommandButton1' me permet de copier des cellules de mon tableau excel et de les coller dans des zones de texte déroulantes sur mon Userform
    - ensuite je peux modifier 1 à 1 ces zones de textes en fonction de choix de ma liste déroulante
    jusqu'ici tout fonctionne correctement .... et instantanément
    - pour valider les changements et les sauvegarder en copiant les valeurs modifiées pour les coller dans le tableau excel j'ai crée un autre bouton 'CommandButton2'

    c'est là que commence le problème : La mise à jour fonctionne MAIS dure plusieurs secondes avant de se terminer.

    ? Pourquoi çà fonctionne bien dans un sens mais très très lentement dans l'autre ?

    ci joint le fichier avec les données code VBA.txt

    Merci

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Possiblement parce que tu copies tes données dans une feuille qui contient des formules et le recalcul peut prendre du temps.
    Dans l'autre sens, il n'y a pas de recalcul puisque tu copies dans un Userform...

  3. #3
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    pour compléter la piste de parmi, si tu as effectivement un nombre conséquent de formules et que le ralentissement est lié au recalcul, essaye de le neutraliser durant l'ajout comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.Calculation = xlCalculationManual
    ' la partie du code qui fait l'ajout
    Application.Calculation = xlCalculationAutomatic
    autre piste : si tu as des procédures évènementielles dans la feuille, elles peuvent également générer un ralentissement
    si c'est bien le cas, et que durant l'ajout tu n'as pas besoin d'utiliser ces procédures évènementielles, tu peux également les neutraliser comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.EnableEvents = False
    ' la partie du code qui fait l'ajout
    Application.EnableEvents = True

    encore une piste, mais peut probable : désactiver le rafraichissement de l'écran :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.ScreenUpdating = False
    ' la partie du code qui fait l'ajout
    Application.ScreenUpdating = True
    bien sûr, ces trois neutralisations peuvent être effectuées toutes ensembles
    bien sûr, ces neutralisations peuvent être étendues à l'ensemble de ta procédure, dans ce cas il faut insérer les deux lignes de code au tout début (et à la toute fin) de ta procédure





    Si aucune proposition n'améliore la durée de traitement, il devient opportun de nous montrer ta procédure complète... je n'ai pas ouvert ton fichier

  4. #4
    Membre averti
    Homme Profil pro
    responsable RH
    Inscrit en
    Janvier 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : responsable RH
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2016
    Messages : 28
    Par défaut
    j'ai résolu mon problème avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.Calculation = xlCalculationManual
    ' la partie du code qui fait l'ajout
    Application.Calculation = xlCalculationAutomatic
    En effet, j'ai beaucoup de formules qui ralentissent la procédure de mise à jour.

    Merci beaucoup pour cette aide rapide et efficace

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

Discussions similaires

  1. BDD sur réseau très très très lent...
    Par ericain dans le forum Access
    Réponses: 12
    Dernier message: 20/02/2015, 17h17
  2. newSchema(url) exécution très très très lente
    Par schum-hacker dans le forum Général Java
    Réponses: 6
    Dernier message: 21/01/2013, 09h32
  3. Exécuter du code VBA placé dans un champ de type mémo
    Par funkyjul dans le forum VBA Access
    Réponses: 8
    Dernier message: 19/07/2010, 09h56
  4. Exécuter le code VBA d'un module dans un sous formulaire
    Par keketteboy dans le forum VBA Access
    Réponses: 2
    Dernier message: 04/06/2008, 11h41
  5. Requête exécutée par code vba
    Par tit65 dans le forum Access
    Réponses: 4
    Dernier message: 22/08/2007, 18h07

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