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 :

Générer une liste dans une ComboBox [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Technicien de laboratoire routier
    Inscrit en
    Novembre 2014
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Technicien de laboratoire routier
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 39
    Par défaut Générer une liste dans une ComboBox
    Bonjour à tous.
    Je cherche à créer une ComboBox dont la liste représente les titres des en-têtes de colonnes d'une de mes feuilles. Mon problème est que le nombre d'en tête n'est pas défini et qu'il y a pas mal de cellules fusionnées. Je suis partis sur une macro pour déterminer le nombre de titre et ainsi définir la variable que je rappellerai dans ma combobox. Il faut prendre en compte l'ajout possible de colonne supplémentaire. Mon problème est que je ne peux pas définir une variable globale à l'intérieur d'un sub. Voici ce que je tente de faire.

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    Sub deftab1()
    'Déclaration des variables
        Dim Dercol As Long
        Dim Nchamps As Long
        Dim Cont As Long
        'Dim tab1() As String
     
        Cont = 1
        Nchamps = 0
     
     
        Dercol = Cells(1, Cells.Columns.Count).End(xlToLeft).Column 
     
     
        While Cont <= Dercol
            If Cells(1, Cont) <> "" Then '
                Nchamps = Nchamps + 1
            End If 'Fin de la condition
            Cont = Cont + 1
        Wend
     
       Global tab1(Nchamps) As String
     
     
     
        Cont = 0
        While Cont <= Nchamps
            If Cells(1, Cont1) <> "" Then
                tab1(Cont) = Cells(1, Cont1)
            End If
       'Wend
    End Sub
    Je ne sais pas si je m'y prends bien mais je sèche complètement, pourriez-vous m'aider svp.

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Dans ce cas-ci, nul besoin de passer par un tableau.

    J'irais comme ceci si le combobox est bien dans un Userform.
    Autrement l'adapter à la feuille.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub UserForm_Initialize()
        Dim I As Long, nbColonnes As Long
     
        nbColonnes = Cells(1, Columns.Count).End(xlToLeft).Column
        For I = 1 To nbColonnes
            If Cells(1, I) <> "" Then Me.ComboBox1.AddItem Cells(1, I)
        Next
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Technicien de laboratoire routier
    Inscrit en
    Novembre 2014
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Technicien de laboratoire routier
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 39
    Par défaut
    super merci

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

Discussions similaires

  1. une liste dans une liste?
    Par JerryOne3 dans le forum C#
    Réponses: 11
    Dernier message: 11/01/2009, 16h43
  2. quand je selectionne une valeur dans une liste, retourne une autre valeur
    Par nsqualli dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 29/12/2008, 14h23
  3. [débutant] Comment gérer une liste dans une liste
    Par Lenoiche dans le forum iReport
    Réponses: 0
    Dernier message: 16/07/2008, 10h41
  4. champ d'une liste lié à une liste dans un autre site
    Par guintolli dans le forum SharePoint
    Réponses: 8
    Dernier message: 08/07/2008, 14h51
  5. Appel d'une liste dans une liste (JSTL)
    Par abalgue dans le forum Hibernate
    Réponses: 4
    Dernier message: 15/06/2007, 10h56

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