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 :

Liste déroulante en VBA (dans une cellule)


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    506
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2009
    Messages : 506
    Par défaut Liste déroulante en VBA (dans une cellule)
    Bonjour,

    J'aimerais créer une liste déroulante (deux colonnes, la première étant invisible mais sera la référence du choix...)

    J'ai essayé avec l'option "validation de données - Liste", mais une seule colonne peut-être référencée... moi j'aimerais deux...

    Je me tourne donc vers le VBA... J'arrive facilement à créer une liste déroulante deux colonnes etc... dans une fenêtre indépendante, mais pas directement dans une cellule...

    Pourriez-vous m'aider ?

    Exemple de liste

    Colonne 1 (invisible) Colonne 2 (visible)
    1 A10 & " vs " & B10
    2 A11 & " vs " & B11
    3 A12 & " vs " & B12
    4 A13 & " vs " & B13
    5 A14 & " vs " & B14
    6 A15 & " vs " & B15
    7 A16 & " vs " & B16
    8 A17 & " vs " & B17
    9 A18 & " vs " & B18
    10 A19 & " vs " & B19

    Merci d'avance

  2. #2
    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 176
    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 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Au stade actuel de mes connaissances, il est impossible d'afficher une liste déroulante dans une cellule avec plus d'une colonne. Seul le bouton ActiveX ComboBox ou ListBox permet d'afficher plus d'une colonne. Il est évidemment possible de l'insérer au moment de la sélection de la cellule mais je trouve que c'est fort lourd.

    Personnellement, j'ai créé une procédure qui détecte au double-click si la cellule contient une Validation de données-List et si c'est le cas, je lance un formulaire de recherche multiple permettant à l'utilisateur de faire une recherche partielle sur des éléments contenus dans une colonne de la liste référencée dans la validation de données et dès qu'il a fait son choix, il fait un double clic dans la liste et j'insère la valeur correspondant à la colonne référencée dans la validation de données.
    Cela me permet de continuer à utiliser les fonctionnalités natives d'excel et n'utiliser le VBA que pour une tâche ponctuelle.
    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

  3. #3
    Membre extrêmement actif
    Homme Profil pro
    Inscrit en
    Septembre 2013
    Messages
    1 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 1 369
    Par défaut
    Bonsoir,

    Exemple de combobox avec 2 colonnes dans une cellule.
    Je ne vois pas pourquoi il y aurait un problème.
    Si on ne veut pas voir la première colonne, il suffit de la mettre à 0 en largeur.
    On peut la déplacer. Récupérer la seconde colonne.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub ComboBox1_GotFocus()
       ComboBox1.List = [liste].Value
    End Sub
    Boisgontier
    Fichiers attachés Fichiers attachés

Discussions similaires

  1. [XL-2007] Listes déroulantes et valeurs dans une même cellule
    Par momo42 dans le forum Excel
    Réponses: 8
    Dernier message: 23/06/2017, 08h50
  2. Réponses: 1
    Dernier message: 02/05/2013, 20h19
  3. [XL-2007] Liste déroulante suivant valeur d'une cellule
    Par malababar dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 27/03/2010, 22h24
  4. [XL-2003] Utiliser une fonction VBA dans une cellule
    Par zakuli dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/08/2009, 19h23

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