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 passage paramètre entre procédure


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 9
    Points : 10
    Points
    10
    Par défaut problème passage paramètre entre procédure
    Bonjour,
    avec le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub messagerie()
    Dim client As Long
    client = CommandBars(1).Controls("ma barre").Controls("EMail").Controls("Messagerie").ListIndex
     
    End Sub
    je récupère l'index d'une liste d'un sous menu après séléction par l'utilisateur sur on action du code suivant de ma barre menu "Messagerie"
    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
    Set Nouveau23 = Nouveau20.Controls.Add(msoControlDropdown, , , , True)
    With Nouveau23
    .Caption = "Messagerie"
    .FaceId = 54
    .Style = msoComboLabel
    .Tag = "Messagerie"
    .TooltipText = "Choisissez votre logiciel de messagerie"
    .OnAction = "messagerie"
    .AddItem ("Outlook Express")
    .AddItem ("Mozilla Thunderbird")
    .AddItem ("Office Outlook")
    .AddItem ("Une autre version pour Outlook2003")
    .AddItem ("Incredimail")
    .AddItem ("Office Outlook 2007")
    .AddItem ("Office2000OutLook")
    End With
    . Je souhaite maintenant récupérer ma variable "client" pour l'utiliser dans un autre module.
    J'ai écrit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub messagerie(client as Integer)
    client = CommandBars(1).Controls("ma barre").Controls("EMail").Controls("Messagerie").ListIndex
    End Sub
    Seulement j'ai une erreur :argument non facultatif.
    Si je rajoute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .OnAction = "messagerie(client)"
    j'ai une erreur "impossible de trouver la macro 'messagerie(client)'.
    Bref, je ne sais pas comment m'en sortir.
    Quel qu'un peut-il m'aider?
    Merci d'avance.

  2. #2
    Membre averti
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Janvier 2007
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Formateur en informatique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 144
    Points : 337
    Points
    337
    Par défaut
    Salut,

    Je ne comprend pas très bien.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .OnAction = "messagerie(client)"
    messagerie C'est le nom d'une de tes procedures???
    Et client c'est une variable à transmetre?

    Si c'est le cas essaye peut-être :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .OnAction = "messagerie(CStr(client))"
    Dit moi ce que sa donne.

  3. #3
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut
    Bonjour

    heu si tu n'as qu'une ligne de code pourquoi dans ton autre module ne pas mettre tout simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    client = CommandBars(1).Controls("ma barre").Controls("EMail").Controls("Messagerie").ListIndex
    Pour essayer de te répondre
    Où as tu mis ton
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .OnAction = "messagerie(client)"


    Si tu veux utiliser la routine messagerie tu fais dans ton bouton
    dans tamacro
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    sub tamacro()
    dim client as integer
     
    messagerie client
    .....

    Autre chose, il me semble que tout ce qui est entre les guillemet est une chaine de caractère et ne sera pas interprété
    "messagerie(CStr(client))"
    va fonctionner si tu as effectivment une macro qui s'appelle messagerie(CStr(client))
    ce qui est difficilement possible


    En relisant le tout je me dis que des explication un peu plus claire serais souhaitable en fait.

    Montre nous la macro qui a besoin de messagerie et comment tu l'appelles.

Discussions similaires

  1. [2.2.1] Problème passage paramètres
    Par svanlierde dans le forum BIRT
    Réponses: 18
    Dernier message: 18/04/2008, 12h00
  2. [VB.NET]Problème passage paramètre par référence
    Par biau dans le forum Windows Forms
    Réponses: 4
    Dernier message: 05/02/2008, 14h03
  3. [XI][C#][vs2005] Problème passage paramètre.
    Par Arkan6262 dans le forum SDK
    Réponses: 4
    Dernier message: 14/09/2007, 09h17
  4. Problème de paramètres entre form
    Par Furlaz dans le forum C++Builder
    Réponses: 18
    Dernier message: 08/06/2006, 11h50
  5. [JSP] Problème passage paramètre
    Par besco dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 13/09/2004, 10h15

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