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 :

Vlookup dans une phrase avec * en vba


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Data Analyst
    Inscrit en
    Mai 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Data Analyst
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2016
    Messages : 13
    Par défaut Vlookup dans une phrase avec * en vba
    Bonjour,

    J'ai trouvé la manière ci-dessous pour chercher un mot dans une phrase :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =VLOOKUP("*"&G3&"*";mots_clés!$A$1:$C$171;2;0)
    Je suis en train de faire une macro vba pour automatiser, mon code ci-après ne fonctionne pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     categorie = "=VLOOKUP(*G" & vlrn & "*;Classification_formation.xlsm]mots_clés!$A$1:$C$171;2;false)"
    Est-ce que vous savez comment rédiger avec l'étoile (*) en vba ?

    Merci d'avance pour votre aide

  2. #2
    Membre chevronné Avatar de Filippo
    Homme Profil pro
    Statisticien
    Inscrit en
    Mai 2004
    Messages
    864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Statisticien

    Informations forums :
    Inscription : Mai 2004
    Messages : 864
    Par défaut
    Hello,
    je me suis fait un petit exemple qui fonctionne avec cette syntaxe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Public Sub ChercheVal()
        Dim stCategorie As String
     
        stCategorie = "=VLOOKUP(""*""&D1&""*"",A:A,1,0)"
        sht_Valeurs.Range("D1").Formula = stCategorie
    End Sub

  3. #3
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par sarahh67 Voir le message
    Est-ce que vous savez comment rédiger avec l'étoile (*) en vba ?
    Ton problème, ce n'est pas l'étoile, c'est les double côte ".
    Pour les intégrer à une chaine de caractère, il faut les doubler.
    Et tu as aussi oublié les & de ta formule.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     categorie = "=VLOOKUP(""*""&G" & vlrn & "&""*"";Classification_formation.xlsm]mots_clés!$A$1:$C$171;2;false)"

  4. #4
    Membre averti
    Femme Profil pro
    Data Analyst
    Inscrit en
    Mai 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Data Analyst
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2016
    Messages : 13
    Par défaut Merci
    Merci beaucoup pour votre aide et votre rapidité de réponse.

  5. #5
    Membre averti
    Femme Profil pro
    Data Analyst
    Inscrit en
    Mai 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Data Analyst
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2016
    Messages : 13
    Par défaut Question supplémentaire
    Bonjour,

    Ma logique était mauvaise j'ai des groupes de mots dans la colonne G par exemple "PowerPoint 2010 Introduction" et dans le tableau "mots_clés!$A$1:$C$171" dans la colonne A "Power point" , j'aimerai que dans la colonne H il me ramène la correspondance de Power Point du tableau "mots_clés!$A$1:$C$171" qui se trouve en colonne 2. Puis-je passer aussi par un Vlookup ? Je devrai mettre les étoiles au niveau du tableau d'information dans lequel les données sont recherchées, je sais pas si c'est fesable.

    Merci d'avance pour votre aide.

  6. #6
    Membre chevronné Avatar de Filippo
    Homme Profil pro
    Statisticien
    Inscrit en
    Mai 2004
    Messages
    864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Statisticien

    Informations forums :
    Inscription : Mai 2004
    Messages : 864
    Par défaut
    Hello,
    si tu veux chercher une chaîne dans une autre chaîne, tu peux utiliser la fonction CHERCHE (SEARCH en vba).

    Par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("H2").Cells.Formula = "=IF(ISERROR(SEARCH(""PowerPoint"",""PowerPoint 2010 Introduction"",1)),""PAS TROUVE"", ""TROUVE"")"
    Qui renvoie "TROUVE" car "PowerPoint" est trouvé dans "PowerPoint 2010 Introduction".

    Si tu veux faire la recherche dans une colonne entière, tu peux utiliser la fonction vba Find; par exemple avec cette syntaxe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub test()
        Dim r As Range
     
        ' A2 = "PowerPoint"
        With shtCherche.Range("G2:G5") ' G2:G5 contient PowerPoint 2010 Introduction dans une de ses cellules
            Set r = .Find(shtCherche.Range("A2").Value, LookIn:=xlFormulas, LookAt:=xlPart, SearchOrder:=xlByColumns)
        End With
     
     
        If Not r Is Nothing Then MsgBox "Trouvé"
        If r Is Nothing Then MsgBox "Pas trouvé"
    End Sub

  7. #7
    Membre averti
    Femme Profil pro
    Data Analyst
    Inscrit en
    Mai 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Data Analyst
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2016
    Messages : 13
    Par défaut Afficher la colonne B
    Merci pour la réponse.

    J'aimerai afficher la cellule de la colonne B correspondante de la feuille "Mots_clés" au lieu de "TROUVE" c'est pour ça que j'avais commencé avec un RechercheV, quand il trouve "PowerPoint" sur ma feuille "Data" dans la colonne A.

    Vous trouverez ci-après un exemple de la construction de mon fichier, j'ai mis en jaune les cellules que j'aimerai compléter avec cette formule :

    exemple.xlsx

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

Discussions similaires

  1. [XL-2010] Recherche dans une matrice avec doublons (formule ou VBA)
    Par Lucorah dans le forum Excel
    Réponses: 7
    Dernier message: 07/05/2012, 17h16
  2. [Toutes versions] VBA - Ouvrir un lien dans une cellule avec un navigateur spécifique
    Par thirdeye dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 19/08/2010, 15h48
  3. Forcer un parametre dans une requete avec VBA
    Par PsykotropyK dans le forum VBA Access
    Réponses: 1
    Dernier message: 09/07/2008, 17h42
  4. Réponses: 4
    Dernier message: 15/06/2006, 10h05
  5. Insertion d'une date dans une table avec vba
    Par skeut dans le forum Access
    Réponses: 2
    Dernier message: 21/02/2006, 08h54

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