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 avec un tableau nommé


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Femme Profil pro
    comptable
    Inscrit en
    Août 2016
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Ariège (Midi Pyrénées)

    Informations professionnelles :
    Activité : comptable
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2016
    Messages : 55
    Par défaut Vlookup avec un tableau nommé
    Bonjour à tous,

    Je n'arrive pas à appliquer le "recherchev" dans mon tableau nommé (insérer, tableau) en VBA. J'ai fait le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Dim tableau As ListObject
    Dim resultat as string
     
    Set tableau = ThisWorkbook.Worksheets("feuille").ListObjects("MonTableauNomme")
    resultat = WorksheetFunction.VLookup(Me.MaCombobox.Value, tableau, 2, False)
    Quelqu'un pourrait-il m'aider ? merci

  2. #2
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut

    Bonjour,

    déjà vérifier manuellement si la formule fonctionne …  Et dans l'affirmative, la poster au moins ici !
    Ensuite expliquer clairement le problème, le numéro de la ligne en cause, l'erreur et son message …

    ___________________________________________________________________________________________________________
    Je suis Paris, London, Istanbul, Berlin, Nice, Bruxelles, Charlie, …

  3. #3
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 168
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Comme la fait clairement remarquer Marc, il faut être plus précis dans sa question. La ligne 6 de ce code a nécessairement enclenché une erreur.
    Le deuxième argument de la fonction VlookUp doit être un objet Range
    Soit tu ajoutes la propriété DataBodyRange dans cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     resultat = WorksheetFunction.VLookup("R083", tableau.DataBodyRange, 2, False)
    Soit tu travailles avec un objet Range au lieu de ListObject comme l'exemple ci-dessous
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     Dim tableau As Range
     Dim resultat As String
     
     Set tableau = ThisWorkbook.Worksheets("db").ListObjects("Tableau1").DataBodyRange
     resultat = WorksheetFunction.VLookup("R083", tableau, 2, False)
     MsgBox resultat
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut. ( Philippe)

    Tu peux aussi directement travailler avec la plage nommée qui pointe vers ton tableau nommé (comme tu le ferais en Excel).

    Si tu as nommé ton tableau t_Donnees, tu peux utiliser range("t_donnees") dans ton code.

    En découle une utilisation simple des tableaux de données, puisque VBA reconnaît les références structurées comme étant des plages nommées. Ainsi, pour un tableau t_Donnees qui contient les colonnes Nom, Prénom, ..., tu peux, en vba, pointer directement vers range("t_donnees[nom]") pour adresser toute la colonne Nom du tableau t_Donnees (hors lignes d'entête et de total).
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  5. #5
    Membre confirmé
    Femme Profil pro
    comptable
    Inscrit en
    Août 2016
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Ariège (Midi Pyrénées)

    Informations professionnelles :
    Activité : comptable
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2016
    Messages : 55
    Par défaut
    Citation Envoyé par Pierre Fauconnier Voir le message
    Salut. ( Philippe)

    Tu peux aussi directement travailler avec la plage nommée qui pointe vers ton tableau nommé (comme tu le ferais en Excel).

    Si tu as nommé ton tableau t_Donnees, tu peux utiliser range("t_donnees") dans ton code.

    En découle une utilisation simple des tableaux de données, puisque VBA reconnaît les références structurées comme étant des plages nommées. Ainsi, pour un tableau t_Donnees qui contient les colonnes Nom, Prénom, ..., tu peux, en vba, pointer directement vers range("t_donnees[nom]") pour adresser toute la colonne Nom du tableau t_Donnees (hors lignes d'entête et de total).
    Merci à tous, j'ai utilisé cette réponse car elle me parait la plus simple, c'est exactement ce que je cherchais !

    Désolé si vous n'avez pas tous trouvé ma question très claire mais j'ai un code plutôt long avec pas mal de plage et cellules nommées et je préférais aller à l'essentiel.

  6. #6
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 168
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Ce n'est pas ta question qui n'est pas claire mais elle n'est pas précise.
    Lorsqu'une procédure ne fonctionne pas, ll y a plusieurs raisons.
    1. Elle ne renvoie pas le résultat escompté
    2. Elle bloque sur une lgne de code et renvoie un message d'erreur

    Dans le premier cas c'est une erreur de conception, dans le deuxième il faut indiquer dans ta question, le numéro de la ligne où a lieu l'erreur, le numéro de l'erreur ainsi que le message qui l'accompagne. En général le fait d'écrire cette dernière t'apporte déjà la réponse.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  7. #7
    Membre confirmé
    Femme Profil pro
    comptable
    Inscrit en
    Août 2016
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Ariège (Midi Pyrénées)

    Informations professionnelles :
    Activité : comptable
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2016
    Messages : 55
    Par défaut
    Merci, j'essayerai de faire plus précis la prochaine fois

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

Discussions similaires

  1. VLOOKUP avec un tableau
    Par Xibalba dans le forum Excel
    Réponses: 7
    Dernier message: 27/03/2012, 11h25
  2. Probleme avec un tableau
    Par Death83 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 14
    Dernier message: 09/12/2005, 01h03
  3. Problème avec un tableau de tableau
    Par SubZero2 dans le forum Langage
    Réponses: 4
    Dernier message: 07/12/2005, 15h25
  4. problème avec un tableau dans un insert ...
    Par vbcasimir dans le forum Langage
    Réponses: 3
    Dernier message: 02/11/2005, 14h31
  5. probleme d allocation avec un tableau de BYTE
    Par e1lauren dans le forum C++
    Réponses: 5
    Dernier message: 06/05/2005, 13h42

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