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 :

Création d'une combobox


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Furr
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    153
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Nord (Nord Pas de Calais)

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 153
    Par défaut Création d'une combobox
    Bonjour,

    Je cherche dans le cadre d'une génération d'un classeur Excel pouvoir associer à une cellule une comboBox, permettant à l'utilisateur de sélectionner des valeurs prédéfinies.
    Pour créer une combobox, j'ai constaté après pas mal de recherche qu'il était possible de réaliser ceci simplement grâce aux userform dans Excel. Mon souci est que ma génération du classeur se fait totalement via un logiciel externe, et donc l'interaction avec Excel ne se fait que via le code de mon application.

    Je voudrais donc savoir si quelqu'un avait déjà été confronté à cette problématique, à savoir de pouvoir créer une combobox dynamiquement, l'affecter ensuite à une ou plusieurs cellules, de manière totalement automatisée, et si, bien sûr, ce quelqu'un aurait des indications (voir un bout de code simpliste dans le meilleur des cas) concernant la marche à suivre

    J'ai fait un bref test grâce aux objets OLE, mais ça ne donne rien de bon, probablement par une mauvaise utilisation

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim comboBox As OLEObject = xlsSheet.OLEObjects.Add(ClassType:="Forms.ComboBox")              
    comboBox.Object.AddItem("Test")
    xlsSheet.Cells(1, 1).Value = comboBox.Object
    Merci d'avance pour l'aide que vous pourrez m'apporter

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Par défaut
    Bonjour,

    Dans un but de simplification, pourquoi ne pas utiliser la validation de donnée
    (Données -> validation sous XLS2003) pour faire apparaître une ComboBox ?

    exemple de code s'exécutant depuis un classeur quelconque, et qui crée dans le classeur "Classeur2 / Feuil1" une comboBox à 4 choix en cellule A1.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        With Workbooks("Classeur2").Worksheets(1).Cells(1, 1).Validation
            .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:="1;2;3;4"
            .IgnoreBlank = True
            .InCellDropdown = True
            .ShowInput = True
            .ShowError = True
        End With

  3. #3
    Membre confirmé Avatar de Furr
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    153
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Nord (Nord Pas de Calais)

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 153
    Par défaut
    Effectivement, une très bonne idée cette validation, je n'y ai pas pensé
    Ça fonctionne très bien, j'ai plus qu'à la paramétrer pour mon cas, merci beaucoup

  4. #4
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Par défaut
    Content d'avoir pu aider à simplifier ici
    Même s'il existe des solutions pour créer dynamiquement des objets,
    la gestion devient sensiblement plus lourde (placement, taille, liste, évènement ...)
    que ces quelques lignes données plus haut.

    Bonnes fêtes de fin d'années.

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

Discussions similaires

  1. Création d'une combobox auto rempli à partir d'une liste excel
    Par kyros21 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 25/11/2011, 15h46
  2. Création d'une combobox dynamique
    Par lou87 dans le forum ASP
    Réponses: 1
    Dernier message: 14/01/2011, 20h32
  3. Réponses: 0
    Dernier message: 27/04/2010, 18h40
  4. PB sur la création d'une combobox
    Par perchman dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 05/02/2009, 18h44
  5. Création d'une combobox liste déroulante
    Par ThieBEN dans le forum IHM
    Réponses: 14
    Dernier message: 15/11/2007, 09h52

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