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

VBA Access Discussion :

Test sur une chaine de caracteres


Sujet :

VBA Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    232
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 232
    Points : 114
    Points
    114
    Par défaut Test sur une chaine de caracteres
    bonjour,

    J'ai un champ LIBELLE1 sur lequel je souhaite effectuer un test , à savoir détecter dans cette chaine de caractère la présence ou nom de certains mots
    EX: Ma chaine de caractère contient-elle les mot "plan" ou "colle"

    Quelle est la manière façon de résoudre ce problème

    merci

  2. #2
    Membre éprouvé

    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    789
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Octobre 2009
    Messages : 789
    Points : 1 266
    Points
    1 266
    Par défaut
    Bonsoir,

    Interesse toi à la fonction Split.
    Cela devrait résoudre ton problème.

    Cordialement

    Christophe

  3. #3
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Bonjour,

    A mon avis, la fonction InStr() est la plus adaptée.

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    232
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 232
    Points : 114
    Points
    114
    Par défaut
    j'ai effectivement essayé avec InStr, cela parait fonctionner mais uniquement lorsque la chaine de caractère se trouve en première position
    Lorsqu'elle se trouve au milieu d'une phrase cela ne fonctionne plus

  5. #5
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Re,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if InStr(LIBELLE, "plan") > 0 or if InStr(LIBELLE, "colle") > 0 then
    msgbox "Trouvé"
    .....

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    232
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 232
    Points : 114
    Points
    114
    Par défaut
    J'avais mis le test = 1, donc je pense qu'il ne devait chercher le mot que sur la première position

  7. #7
    Membre éprouvé

    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    789
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Octobre 2009
    Messages : 789
    Points : 1 266
    Points
    1 266
    Par défaut
    Bonsoir,

    Essaie ceci :

    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
    17
    18
    19
    20
    Sub DoesItemExist(sList As String, _
                           sDelimiter As String, _
                           sItem As String) _
     
    'sList = ta chaîne de texte
    'sDelimiter = le délimiteur de chaîne (pour toi à priori c'est l'espace)
    'sItem = le mot que tu recherche
     
       Dim sItems() As String
     
       sItems = Split(sList, sDelimiter)
     
       Dim i As Integer
       For i = LBound(sItems) To UBound(sItems)
          If i=sItem Then
               MsggBox i
          End If
       Next i
     
    End Sub
    Exemple pour appeler le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Call DoesItemExist("Je recherche ce mot"," ","mot")
    Cordialement

    Christophe

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    232
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 232
    Points : 114
    Points
    114
    Par défaut
    merci
    je vais essayer ta proposition

Discussions similaires

  1. fonction replaceFirst sur une chaine de caractere
    Par marcxa44 dans le forum Langage
    Réponses: 1
    Dernier message: 08/10/2007, 14h22
  2. Test sur une chaine de caractéres
    Par Je-cherche-pfe dans le forum C#
    Réponses: 3
    Dernier message: 05/09/2007, 00h44
  3. Conditions sur une chaine de caractères
    Par xenos dans le forum Delphi
    Réponses: 2
    Dernier message: 21/05/2006, 23h56
  4. [VBA-E] test sur une chaine de charactère
    Par gruget dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 10/04/2006, 15h24
  5. fread sur une chaine de caractere ?
    Par Battosaiii dans le forum C
    Réponses: 17
    Dernier message: 18/03/2006, 13h50

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