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 :

Formules excel écrites via VBA


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut Formules excel écrites via VBA
    Bonjour,

    Je cherche à insérer des formules excel via VBA à l'aide de ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Worksheets(Principale).Range("O7").value = "=if(D7="";"";BDP($C7;$O$6))"
    Cependant j'ai un
    Run-time error '13':
    Type mismatch

    Comment cela se fait?

    Merci pour vos réponses

  2. #2
    Membre émérite

    Homme Profil pro
    Technicien Métrologie R&D
    Inscrit en
    Janvier 2007
    Messages
    1 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien Métrologie R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 610
    Points : 2 523
    Points
    2 523
    Billets dans le blog
    1
    Par défaut
    fait un tour du coté de l'aide en ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .Range("O7").formulaR1C1=
    si tu veut le truc plus simple fait un enregistrement de macro via l'enregistreur

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    J'ai type mismatch maintenant...

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    752
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 752
    Points : 832
    Points
    832
    Par défaut
    Elles sont en anglais tes formules Excel? Moi j'ai la version français où on tape SI, et l'autre fonction je vois pas du tout ce que c'est.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    oui c'est en anglais.
    L'autre est une formule bloomberg. Mais ma fonction n'est pas le probleme, elle est bonne.

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    752
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 752
    Points : 832
    Points
    832
    Par défaut
    Ah je viens de voir ce qui ne va pas.

    Mets ça à la place:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "=if(D7="""";"""";BDP($C7;$O$6))"

  7. #7
    Membre émérite

    Homme Profil pro
    Technicien Métrologie R&D
    Inscrit en
    Janvier 2007
    Messages
    1 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien Métrologie R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 610
    Points : 2 523
    Points
    2 523
    Billets dans le blog
    1
    Par défaut
    la formule avec formulaR1C1 donne un truc en R[-5]
    la formule
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(F7>E7;E7;MAX(E3:G5))
    donne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        Range("F9").FormulaR1C1 = "=IF(R[-2]C>R[-2]C[-1],R[-2]C[-1],MAX(R[-6]C[-1]:R[-4]C[1]))"
    c'est sur qu'au niveau clarté c'est pas du 100W basse consommation

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par decondelite Voir le message
    Ah je viens de voir ce qui ne va pas.

    Mets ça à la place:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "=if(D7="""";"""";BDP($C7;$O$6))"
    Le type mismatch persiste malheuresement

  9. #9
    Membre émérite Avatar de Godzestla
    Homme Profil pro
    Chercheur de bonheur
    Inscrit en
    Août 2007
    Messages
    2 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de bonheur
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 2 392
    Points : 2 985
    Points
    2 985
    Par défaut
    Citation Envoyé par Loki83 Voir le message
    Le type mismatch persiste malheuresement
    Oui, mais c'est quoi ce BDP ?
    Cela ne vient pas de là ?

  10. #10
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par Daranc Voir le message
    la formule avec formulaR1C1 donne un truc en R[-5]
    la formule
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(F7>E7;E7;MAX(E3:G5))
    donne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        Range("F9").FormulaR1C1 = "=IF(R[-2]C>R[-2]C[-1],R[-2]C[-1],MAX(R[-6]C[-1]:R[-4]C[1]))"
    c'est sur qu'au niveau clarté c'est pas du 100W basse consommation
    Heu pourquoi utilise tu des ">" "<" ?
    Mon if sert à afficher une valeur nulle si une cellule que j'ai spécifié est vide

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par Godzestla Voir le message
    Oui, mais c'est quoi ce BDP ?
    Cela ne vient pas de là ?
    Je vais tester sans BDP
    BDP est un addin excel fournit par Bloomberg

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        Worksheets(Principale).Range("O7").value = "3"
    Meme pour ça j'ai une erreur type mismatch....
    Je comprends pas là...

  13. #13
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    soit tu utilises FormulaLocal (français) et c'est SI( ... ; ... ; ...)
    soit tu utilises Formula (anglais) et c'est IF( ... , ... , ... )

    idem pour les R1C1

  14. #14
    Membre émérite

    Homme Profil pro
    Technicien Métrologie R&D
    Inscrit en
    Janvier 2007
    Messages
    1 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien Métrologie R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 610
    Points : 2 523
    Points
    2 523
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Loki83 Voir le message
    Heu pourquoi utilise tu des ">" "<" ?
    Mon if sert à afficher une valeur nulle si une cellule que j'ai spécifié est vide
    non je ne t'ai donné qu'un exemple tu as la première formule telle que dans la feuille (tès simple) et l'autre "traductionnée" par l'enregistreur de macro ce qui explique mon commentaire sur la clarté de la chose

  15. #15
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 126
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par cafeine Voir le message
    Hello,

    soit tu utilises FormulaLocal (français) et c'est SI( ... ; ... ; ...)
    soit tu utilises Formula (anglais) et c'est IF( ... , ... , ... )

    idem pour les R1C1
    Mon Excel doit être hybride car il est en anglais et utilise les ";" comme séparateur...

    Je pense qu'en utilisant l'enregistreur de macro comme vous l'avez dit je devrai m'en sortir!

    Merci !

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

Discussions similaires

  1. Formule Excel en code VBA
    Par enretard dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 10/11/2011, 15h19
  2. Exécution automatique d'une formule Excel à partir de VBA
    Par jumiara dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 02/11/2010, 12h13
  3. [E-00] Transcrire une formule Excel en script VBA
    Par ritournelle dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 16/10/2008, 11h53
  4. probleme insertion formule dans cellule via vba
    Par moxo01 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 20/06/2008, 11h06
  5. Transformé une formule Excel en script VBA ?
    Par SFLEY dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 06/01/2007, 11h48

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