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 avec worksheet function


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Inscrit en
    Avril 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 62
    Points : 35
    Points
    35
    Par défaut problème avec worksheet function
    Bonjour tout le monde

    Voilà, j'ai le bout de code suivant qui me permet d'effectuer une recherche d'une chaine de caractère dans une autre chaine de caractère :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.WorksheetFunction.Find(chaine1, chaine2)
    où "chaine1" et "chaine2" sont deux chaines de caractère.

    Lorsque chaine1 se situe dans chaine2, pas de problème, mais lorsque chaine1 n'est pas dans chaine2, le message d'erreur suivant apparaît :
    "impossible de lire la propriété Find de la classe WorksheetFunction"

    est-ce que quelqu'un pourrait m'aider, svp?

    je précise que je suis sous excel 2010

  2. #2
    Membre émérite Avatar de Fvandermeulen
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2007
    Messages
    1 869
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 869
    Points : 2 662
    Points
    2 662
    Par défaut
    Salut,

    A mon sens il vaut mieux utiliser les fonctions VBA que les WorksheetFunction.
    Pour ton cas la fonction à utiliser est InStr

    Une recherche dans l'aide VBA te donnera l'explication des arguments, dans ton cas tu peux l'utiliser ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    test = instr(1, chaine2, chaine1, 1)
    Si tu dimensionne ta variable en Boolean tu auras False si non trouvé, avec une dimension Integer tu auras la position du texte cherché dans le texte source ou 0 si il n'est pas dans le text

    A+

  3. #3
    Membre habitué
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Mai 2010
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2010
    Messages : 120
    Points : 175
    Points
    175
    Par défaut
    Salut,

    Je ne suis pas sûr que tu uses du meilleur moyen pour rechercher une chaîne dans une autre.
    En effet, là tu fais appel à une fonction Excel dans VBA alors qu'il existe une fonction VBA qui le fait : Instr

    Ton problème est sans doute lié au dernier argument falcutatif que tu n'as pas saisi mais je ne saurais t'aider mieux que ça.

  4. #4
    Nouveau membre du Club
    Inscrit en
    Avril 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 62
    Points : 35
    Points
    35
    Par défaut
    Effectivement, en utilisant instr, ça fonctionne mieux

    merci!!

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

Discussions similaires

  1. [AC-2003] Problème avec call function
    Par cluster26 dans le forum VBA Access
    Réponses: 1
    Dernier message: 29/09/2010, 12h41
  2. [Pentaho] Problème avec PageOfPages function
    Par wafaingstat dans le forum Pentaho
    Réponses: 0
    Dernier message: 25/02/2010, 10h51
  3. Réponses: 19
    Dernier message: 16/09/2008, 11h44
  4. Problème avec une FUNCTION
    Par PoichOU dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 13/09/2007, 10h24
  5. [boost] Problème avec boost::function
    Par Bakura dans le forum Boost
    Réponses: 3
    Dernier message: 22/03/2007, 20h08

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