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 :

Appel d'une Macro dans une Fonction


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Technicien Informatique
    Inscrit en
    Janvier 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Technicien Informatique
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2013
    Messages : 2
    Par défaut Appel d'une Macro dans une Fonction
    Bonjour,

    Voilà mon soucis :

    J'ai une fonction qui s'appelle "RechercheMultSep" avec un séparateur pour chaque résultat à la formule.
    Mon soucis est que si j'enlève mon séparateur et que je veux faire appelle à ma macro "CelChange" pour changer de cellule à chaque résultat ça ne marche pas !
    J'aimerais savoir comment je peux faire soit pour appeler ma macro dans la fonction ou bien changer ma fonction pour que les résultats s'incrivent dans une cellule à chaque fois.
    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
    Function RechercheMultSep(ValeurCherchée As String, MatriceCherche, MatriceTrouve, Optional Separator As String) As String
    Dim c, i As Long
        If Separator = "" Then Separator = "; "
            For Each c In MatriceCherche
                i = i + 1
    If ValeurCherchée = c Then
    If RechercheMultSep = "" Then
    RechercheMultSep = MatriceTrouve(i)
    Else
    RechercheMultSep = RechercheMultSep & Separator & MatriceTrouve(i)
    End If
    End If
    Next c
    End Function
    Et voici ma macro :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub CelChange()
          Rows("1:1").Select
             Selection.Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    End Sub
    J'aimerais au possible ne pas trop modifier ma fonction ou alourdir mon fichier...
    Merci

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Ça ne fonctionnera pas. Le code de la macro se comporte comme s'il était partie intégrante de la fonction. En espérant me tromper, toutefois...

  3. #3
    Candidat au Club
    Homme Profil pro
    Technicien Informatique
    Inscrit en
    Janvier 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Technicien Informatique
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2013
    Messages : 2
    Par défaut
    Merci Daniel pour ta réponse, en fait je m'en doutais...
    Mais dans ce cas y a-t-il une autre solution, car sur mon fichier je recherche toutes mes réfenrences ayant le chiffre 1 dans une colonne et je voudrais que chaque résultat puisse s'incrire dans une cellule l'une après l'autre...
    Faut-il que je revois ma fonction oubien faut-il une nouvelle macro pour obtenir ce résultat?

  4. #4
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Une fonction retourne une valeur. Utilise une macro.

Discussions similaires

  1. Utiliser une valeur d'une variable dans une Macro
    Par ca_adrien dans le forum Macro
    Réponses: 7
    Dernier message: 01/08/2013, 14h14
  2. utiliser une macro dans une macro
    Par Calimero33 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/07/2010, 17h48
  3. Réponses: 2
    Dernier message: 24/02/2009, 17h40
  4. écrire le résultat d'une macro dans une cellule d'une feuille à choisir
    Par ririrourou dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 03/06/2008, 11h56
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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