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 syntaxe appel de fonction [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 53
    Par défaut Problème syntaxe appel de fonction
    Bonjour tout le monde !

    La fonction RTD("MLRTD.RTDFunctions";;"Price";"CR1\H123.4.EO";"Delta") me permet d'aller récupérer la valeur "Delta" de l'actif "CR1\H123.4.EO" sur un logiciel de données dynamique (Marketmap).

    Je souhaite créer une macro (pas par formule donc..) qui me donne dans la cellule (2,3) le "Delta" en fonction du nom de l'actif que rentre l'utilisateur dans la cellule (3,1)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Sub Delta()
    Cells(2,3).value = "=RTD("MLRTD.RTDFunctions";;"Price";Cells(3,1).value;"Last")
    End Sub
    Message d'erreur "Erreur de syntaxe"; si quelqu'un a une idée sur la syntaxe je suis preneur !

  2. #2
    Membre émérite
    Homme Profil pro
    Contrôleur de gestion en activité
    Inscrit en
    Juillet 2012
    Messages
    545
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Contrôleur de gestion en activité
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2012
    Messages : 545
    Par défaut
    Bonjour,

    en vba, le ";" devient ","

    essaye avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub Delta()
    Cells(2,3).value = "=RTD("MLRTD.RTDFunctions",,"Price",Cells(3,1).value,"Last")
    End Sub

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 53
    Par défaut
    Merci de ta réponse mais même après avoir remplacé il y a toujours "erreur de syntaxe".

  4. #4
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    En plus il faut doubler les "

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub Delta()
     
    Cells(2, 3).Formula = "=RTD(""MLRTD.RTDFunctions"",,""Price""," & Cells(3, 1).Value & ",""Last"")"
    End Sub

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 53
    Par défaut
    C'est bon, il fallait aussi doubler les " pour la partie & cells().value&

    Merci à tous.

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 53
    Par défaut
    Désolé de revenir là dessus mais en fait ce n'est pas résolu !
    le but est que la formule dans la cellule (2,3)soit sous cette forme:
    "=RTD("MLRTD.RTDFunctions";;"Price"; "valeur_cellule(3,1)";"Delta")"


    Avec la macro suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Sub Delta()
     Cells(2, 3).Formula = "=RTD(""MLRTD.RTDFunctions"",,""Price""," & Cells(3, 1).Value & ",""Delta"")"
    End Sub
    la formule est :"=RTD("MLRTD.RTDFunctions";;"Price"; valeur_cellule(3,1);"Delta")"
    Donc sans les "" autour de valeur_cellule(3,1)

    et avec la macro suivante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Sub Delta()
     Cells(2, 3).Formula = "=RTD(""MLRTD.RTDFunctions"",,""Price"","" & Cells(3, 1).Value & "",""Delta"")"
    End Sub
    La formule est : "=RTD("MLRTD.RTDFunctions";;"Price", " & cells(3,1).value &";"Delta"")"

    Bref c'est tout bête mais je ne vois pas la solution !
    Merci d'avance.

  7. #7
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub Delta()
     
    Cells(2, 3).Formula = "=RTD(""MLRTD.RTDFunctions"",,""Price"",""" & Cells(3, 1).Value & """,""Last"")"
    End Sub

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

Discussions similaires

  1. Problème d'appel de fonction ???
    Par grumly22 dans le forum Langage
    Réponses: 18
    Dernier message: 03/05/2006, 14h52
  2. Problème d'appel de fonction
    Par claralavraie dans le forum Langage SQL
    Réponses: 1
    Dernier message: 16/12/2005, 20h17
  3. Réponses: 7
    Dernier message: 10/09/2005, 16h49
  4. [DLL] problème pour appeler une fonction d'une DLL
    Par bigboomshakala dans le forum MFC
    Réponses: 34
    Dernier message: 19/07/2004, 11h30
  5. Réponses: 4
    Dernier message: 19/04/2004, 13h41

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