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 :

Fonction non valide ( exécution fonction excel vba)


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Inscrit en
    Février 2012
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2012
    Messages : 11
    Par défaut Fonction non valide ( exécution fonction excel vba)
    Bonjour à tous, j'ai fais une petite fonction VBA qui à chaque fois qu'elle trouve le mot "Immediat" dans la 3eme colonne , vas chercher la valeur qui se trouve dans 12 colonnes à droite. Et puis je fais la somme de toutes ces valeurs.

    Alors mon problème c'est que quand je fais un Message Box classique , j'obtiens bien le bon chiffre (et donc que ma fonction fonctionne) mais ça ne marche pas quand j'essaie d’appeler ma fonction dans Excel (j'obtiens un "fonction non valide") ou que j'essaie de l'appeler dans mon code de cette façon (en voulant afficher mon résultat dans une cellule)

    ActiveCell.Offset(1, 1).Value = Resultat()

    Voici ma fonction :

    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
    17
    18
    19
    20
    21
    22
    23
    Public Function Resultat() As Double
    Sheets("Valo RBC Dexia").Select
     
    Dim Result As Double
    Result = 0
    Cells(1, 3).Activate
     
    Do While ActiveCell.Value <> "IMMEDIATE"
    ActiveCell.Offset(1, 0).Select
    Loop
     
     
    Do While ActiveCell.Value = "IMMEDIATE"
    Result = ActiveCell.Offset(0, 12).Value + Result
    ActiveCell.Offset(1, 0).Select
    Loop
     
     
    Resultat = Result
     
    MsgBox Result
     
    End Function
    Est ce que quelqu'un arrive à voir pourquoi ça ne marche pas?
    Je vous remercie d'avance

  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 : 51
    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,

    Retrouves tu ta fonction dans la liste des fonctions personnalisées ?
    As tu mis cette fonction dans un module ?

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Par défaut
    Bonjour,

    Comme JFontaine le souligne, je doute que la fonction fasse partie d'un module (ligne 6 ne compilerait pas).

    Avec le code ci-dessous, ça devrait fonctionner même dans un module, est sans faire de sélection ...

    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
    17
    18
    19
    Option Explicit
     
    Function Resultatv2() As Double
        Dim c As Range
        Dim isImmediate As Boolean
        Resultatv2 = 0
        isImmediate = False
     
        For Each c In Worksheets("Valo RBC Dexia").Range("C1:C" & Worksheets("Valo RBC Dexia").[C65000].End(xlUp).Row)
     
            If c.Value = "IMMEDIATE" Then
                isImmediate = True
                Resultatv2 = Resultatv2 + c.Offset(0, 12).Value
            ElseIf isImmediate Then
                Exit For
            End If
     
        Next c
    End Function

  4. #4
    Membre averti
    Inscrit en
    Février 2012
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2012
    Messages : 11
    Par défaut
    Déjà merci à vous pour vos réponses.

    Alors oui ma fonction était déjà dans le Module 1 et Excel reconnaissait ma fonction.

    Sinon j'ai testé la 2eme fonction elle renvois zéro...

    EDIT : Alors j'ai oublié de changer "Feuil1" en "Valo RBC Dexia" (j'avais fais un copier coller direct)
    Alors maintenant ça marche, sous excel j'ai bien le bon résultat.

    Par contre si je voulais afficher cela en VBA , il faudrait faire ceci ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(8, 5).Value = Resultatv2()
    Parce que ça ne marche pas

    Merci encore

  5. #5
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Par défaut
    Re.

    Par contre si je voulais afficher cela en VBA , il faudrait faire ceci ?
    Cells(8, 5).Value = Resultatv2()
    C'est bien ça effectivement.

    Parce que ça ne marche pas
    Quel est le symptôme de l'erreur ?
    Lorsqu'on écrit Cells(<ligne>,<col>) on doit se trouver dans le code d'une feuille.(pas dans un module).
    Pour afficher le résultat dans la feuille "Mafeuille" depuis un module, il faudrait écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Worksheets("Mafeuille").Cells(8, 5).Value = Resultatv2()

  6. #6
    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 : 51
    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
    Salut BlueMonkey,

    Je vais te contredire, mais Cells(<ligne>,<col>) fonctionne dans un module.
    Seulement, on fait référence à la feuille active, même si elle se trouve sur un autre classeur de l'instance d'application.

  7. #7
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Par défaut
    Bonjour JFontaine,

    Effectivement j'ai dis une sottise sur les Cells appelé depuis un module.

    A ma décharge, ça reste toute de même une bonne habitude de faire référence au classeur à ce niveau là.

  8. #8
    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 : 51
    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
    A ma décharge, ça reste toute de même une bonne habitude de faire référence au classeur à ce niveau là.
    Bien d'accord avec toi

Discussions similaires

  1. Réponses: 3
    Dernier message: 02/07/2013, 20h49
  2. [XSLT][XPATH] current-date() fonction non-valide
    Par exe2bin dans le forum XSL/XSLT/XPATH
    Réponses: 4
    Dernier message: 21/03/2010, 14h30
  3. [VBA] Fonction non définie dans l'expression
    Par DREADY dans le forum VBA Access
    Réponses: 17
    Dernier message: 08/03/2007, 16h49
  4. [Excel VBA]fonction dans une cellule qui modifie une autre cellule
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 24/01/2007, 17h43
  5. [VBA-E]Fonction vb depuis la feuille excel
    Par Pollux dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 15/02/2006, 18h41

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