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 :

[E-03] OnTime et paramètres


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné Avatar de drakkar_agfa
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    618
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Canada

    Informations forums :
    Inscription : Septembre 2008
    Messages : 618
    Par défaut [E-03] OnTime et paramètres
    Bonjour,

    Question simple, est-ce possible de passer des paramètres avec OnTime
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        Application.OnTime Now + TimeValue("00:00:05"), "MaProc(MaVariable)"
    Quelque chose ressemblant à ceci.

    Si ce n'est pas possible, une variable globale?

    Merci de vos suggestions!

  2. #2
    Membre émérite
    Avatar de fred65200
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    901
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 901
    Par défaut
    bonjour, deux exemples avec un ou deux paramètres
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Test()
        Application.OnTime Now + TimeValue("00:00:02"), "'MaProc1  ""Test1""'"
        Application.OnTime Now + TimeValue("00:00:05"), "'MaProc2  ""Test"", 3'"
    End Sub
    Sub MaProc1(MaVariable)
        MsgBox MaVariable
    End Sub
    Sub MaProc2(MaVariable, X)
            MsgBox MaVariable & X
    End Sub
    Attention aux " et '
    Cordialement

  3. #3
    Membre émérite
    Avatar de fred65200
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    901
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 901
    Par défaut
    trouvé depuis gràce à Silkyroad
    http://excel.developpez.com/faq/?pag...rgumentsOnTime

    fred

  4. #4
    Membre chevronné Avatar de drakkar_agfa
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    618
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Canada

    Informations forums :
    Inscription : Septembre 2008
    Messages : 618
    Par défaut
    Et oui c'est parfait!

    Merci bien!

  5. #5
    Membre chevronné Avatar de drakkar_agfa
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    618
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Canada

    Informations forums :
    Inscription : Septembre 2008
    Messages : 618
    Par défaut
    Bonjour,

    Au moment du test, ta macro fonctionne parfaitement. Quand j'essais de faire la mienne... on a un problème.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub MaProc()
        Dim sMessage As String
     
        sMessage = InputBox("Entrez le message")
        Application.OnTime Now + TimeValue("00:00:01"), "'LancerMessage ,sMessage'"
    End Sub
    Sub LancerMessage(Message As String)
        MsgBox ("Voici le message donné :" & Chr(10) & Message)
    End Sub
    Je suis capable de lui donner le message (en texte "") mais pas par variable... Est-ce possible?

    Je dois avoir un problème avec les " et les '

    Merci encore!

  6. #6
    Expert confirmé

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Par défaut
    bonsoir

    Tu as également une virgule de trop dans le paramétrage de l'argument.

    Tu peux tester cette adaptation :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Sub MaProc()
        Dim sMessage As String
     
        sMessage = InputBox("Entrez le message")
        Application.OnTime Now + TimeValue("00:00:01"), "'LancerMessage " _
            & Chr(34) & sMessage & Chr(34) & "'"
    End Sub
     
    Sub LancerMessage(Message As String)
        MsgBox ("Voici le message donné :" & Chr(10) & Message)
    End Sub


    bonne soirée
    michel

  7. #7
    Membre émérite
    Avatar de fred65200
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    901
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 901
    Par défaut
    bonsoir drakkar_agfa, silkyroad
    il y a aussi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        Application.OnTime Now + TimeValue("00:00:01"), "'LancerMessage """ & sMessage & """'"
    @+

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

Discussions similaires

  1. Paramètres avec Application.OnTime
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 07/11/2007, 17h50
  2. [VBA-E] OnAction/OnTime avec paramètre(s)
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 20/01/2006, 16h08
  3. [SWT] Problème de paramètre GridData
    Par yolepro dans le forum SWT/JFace
    Réponses: 4
    Dernier message: 06/12/2002, 10h37
  4. passage en paramètre d'un array dynamique 2D
    Par Guigui_ dans le forum Langage
    Réponses: 4
    Dernier message: 27/11/2002, 19h47
  5. Paramètre requete SQL (ADOQuery)
    Par GaL dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/07/2002, 11h24

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