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 :

Problème avec Application.Volatile


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Homme Profil pro
    Ingénieur
    Inscrit en
    Janvier 2010
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2010
    Messages : 272
    Par défaut Problème avec Application.Volatile
    Bonjour à tous,

    Je rencontre un problème avec, je présume, la fonction Application.volatile. Je m'explique:

    J'ai codé une fonction volatile en VBA, nommée "logigramme", que j'appelle dans une cellule d'un onglet A via =logigramme(). Elle fonctionne bien, c'est à dire que le résultat qui apparaît est bien mis à jour suivant les valeurs prises par d'autres cellules du même onglet.

    Maintenant, je lance le code VBA d'un autre onglet B. Le calcul a lieu, se termine correctement. Je reviens sur l'onglet A, et le résultat de logigramme() a changé ! Alors que les cellules qui servent d'argument à la fonction n'ont pas changé de valeur...

    Auriez-vous une explication rationnelle à cela ? A priori, le code de l'onglet B ne vient pas perturber celui de l'onglet A...
    Merci d'avance

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 174
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Si tu as écrit une fonction volatile celle-ci se recalcule chaque fois que l'on modifie la valeur de n'importe quelle cellule, de n'importe quelle feuille, de n'importe quel classeur ouvert.
    Il y a 7 fonctions volatiles dans excel qui fonctionnent de la même manière.
    Par exemple, si tu tapes =MAINTENANT() dans la cellule A1 de la feuil1, il t'affiche la date et l'heure de maintenant. Tu ne fais rien pendant 5 minutes, l'heure ne bougera pas. Dès que tu taperas une valeur dans une cellule de cette feuille ou d'une autre feuille, l'heure changera puisque la fonction MAINTENANT() étant volatile aura refait le calcul.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre éclairé
    Homme Profil pro
    Ingénieur
    Inscrit en
    Janvier 2010
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2010
    Messages : 272
    Par défaut
    Bonjour,

    Merci pour ces éclairements, je pense que nous sommes d'accord sur le fonctionnement d'une fonction volatile.
    Ce qui m'étonne, c'est que la fonction affiche un résultat dont la valeur dépend des paramètres d'autres cellules, disons A et B.

    J'entre A et B, j'ai le résultat 1.
    J'exécute un autre code sans modifier A et B.
    Je retourne voir le résultat : j'obtiens le résultat 2, alors que A et B n'ont pas changé.
    Admettons que le résultat est A+B, dans le premier cas j'obtiendrais bien la bonne somme. Après exécution d'un code j'aurais alors un mauvais résultat !

    Quelle pourrait être la solution pour contourner cela ?

    Merci encore,

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 174
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    N'utilises-tu pas une variable déclarée Static ?
    Il serait peut-être intéressant d'afficher le code de ta fonction afin de pouvoir apporter une réponse pertinente.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #5
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 196
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 196
    Billets dans le blog
    2
    Par défaut
    Bonjour d0n32, Bonjour Philippe, ,

    si ta fonction est dépendante de valeurs de cellules, as-tu bien précisé dans ton code la feuille à laquelle appartiennent ces cellules ?
    Si non, il recalcule en fonction de la feuille active, et comme elle est volatile ça pose problème...

  6. #6
    Membre éclairé
    Homme Profil pro
    Ingénieur
    Inscrit en
    Janvier 2010
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2010
    Messages : 272
    Par défaut
    Erreur de débutant....
    Merci tototiti, merci à vous 2, c'est parfait !

  7. #7
    Membre averti
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Mars 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Consultant en technologies

    Informations forums :
    Inscription : Mars 2018
    Messages : 30
    Par défaut
    Bonjour à tous ,
    Je rencontre le même problème mais je n'ai pas compris la solution proposée .Voilà mon code :
    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
    Function Effective() As Double
     
    Application.Volatile
    Dim J As Long
    Dim i As Double
     
    Effective_Design = 0
      For J = 2 To Sheets("Test").Range("C" & Rows.Count).End(xlUp).Row
        If Sheets("Test").Range("C" & J) <> "" Then
           Effective = Effective + (3 * Sheets("Test").Range("E" & J))
     
        End If
      Next J
     
     
    End Function

  8. #8
    Membre confirmé
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2016
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2016
    Messages : 27
    Par défaut
    Bonjour,

    Je n'ai pas testé mais j'ai l'impression qu'en remplaçant la ligne
    Effective_Design = 0 ???
    par
    Effective = 0

    On réinitialise le comptage et on doit avoir le résultat souhaité

    Est-ce le cas ?

  9. #9
    Membre averti
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Mars 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Consultant en technologies

    Informations forums :
    Inscription : Mars 2018
    Messages : 30
    Par défaut
    Non ça n'a rien à voir .

  10. #10
    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
    Si ça n'a rien à voir, alors que fait cette variable dans ta fonction ?

    Elle n'est ni déclarée, tu la spécifies à 0 et tu ne l'utilises pas

    Décris aussi le comportement inattendu qui se produit !

  11. #11
    Membre averti
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Mars 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Consultant en technologies

    Informations forums :
    Inscription : Mars 2018
    Messages : 30
    Par défaut
    Citation Envoyé par joe.levrai Voir le message
    Si ça n'a rien à voir, alors que fait cette variable dans ta fonction ?

    Elle n'est ni déclarée, tu la spécifies à 0 et tu ne l'utilises pas

    Décris aussi le comportement inattendu qui se produit !
    La variable est bonne . Il s'agit d'initaitalisation de la fonction Effective . Là il s'agit de code juste modifié .
    Quand j'ouvre un autre fichier , la fonction donne erreur .
    Par contre , si je saisi une autre valeur la fonction fonctionne correctement .

  12. #12
    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
    Bref, laissons cette ligne de code inutile de côté

    Ta fonction cherche la feuille Sheets("Test") dans le classeur qui est considéré comme actif

    Je te conseille de préfixer ta feuille avec le classeur dans lequel tu souhaites faire la recherche et le calcul

  13. #13
    Membre averti
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Mars 2018
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Consultant en technologies

    Informations forums :
    Inscription : Mars 2018
    Messages : 30
    Par défaut
    Citation Envoyé par joe.levrai Voir le message
    Bref, laissons cette ligne de code inutile de côté

    Ta fonction cherche la feuille Sheets("Test") dans le classeur qui est considéré comme actif

    Je te conseille de préfixer ta feuille avec le classeur dans lequel tu souhaites faire la recherche et le calcul
    Oui mais si la feuille Test n'existe pas dans un autre fichier pourquoi il prend d'autres valeurs ?
    Comment préfixer le classeur ?

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

Discussions similaires

  1. Problème avec Application.Dialogs(xlDialogSaveAs).Show
    Par melouille56 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 20/12/2007, 18h54
  2. Problème avec Application.OnTime
    Par Uopip dans le forum VBA Outlook
    Réponses: 14
    Dernier message: 09/07/2007, 15h14
  3. Problème avec Application.Minimize
    Par Alchemist dans le forum Delphi
    Réponses: 1
    Dernier message: 27/01/2007, 21h49
  4. [VBA-E] Problème avec Application.StatusBar
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 04/03/2006, 16h44
  5. problème avec Application->ProcessMessages()
    Par petitours dans le forum C++Builder
    Réponses: 4
    Dernier message: 15/08/2005, 10h27

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