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 :

ComboBox à 2 colonnes [XL-2016]


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Retraité
    Inscrit en
    Juin 2021
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Retraité
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Juin 2021
    Messages : 7
    Points : 7
    Points
    7
    Par défaut ComboBox à 2 colonnes
    Bonjour
    Je souhaite alimenter une ComboBox à 2 colonnes avec le code suivant

    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
    Sub FCombo()
     
        Dim i As Integer
     
        Sheets("Event").Select
        Sheets("Event").Unprotect
            Sheets("Event").ComboBox1.Clear  ' ==> erreur
     
        LColCombo = Sheets("Inscriptions").Cells(6, Columns.Count).End(xlToLeft).Column
     
        For i = 8 To LColCombo
           Range("XFC" & i - 7) = Sheets("Inscriptions").Cells(6, i)
           Range("XFD" & i - 7) = Sheets("Inscriptions").Cells(3, i)
        Next
     
        RColCombo = Cells(Rows.Count, "XFC").End(xlUp).Row
     
        Sheets("Event").ComboBox1.ListFillRange = Sheets("Inscriptions").Range("XFC1:XFD" & RColCombo) '==> Erreur
     
    End Sub
    Pourriez-vous m'aider ?
    Merci d'avance

  2. #2
    Responsable
    Office & Excel


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

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

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 924
    Points
    55 924
    Billets dans le blog
    131
    Par défaut
    Salut.

    J'ai de gros doutes sur une conception de classeur qui va chercher des valeurs en XFC et XFD. Je pense aussi que l'on pourrait simplifier ce code mais sans savoir ce que tu souhaites réaliser, il est malaisé de t'aider davantage.

    Cela étant, voici un code qui pourrait convenir: Sheets("Event").ComboBox1.List = Sheets("Inscriptions").Range("XFC1:XFD" & RColCombo).Value
    Perso, je travaillerais avec des tableaux structurés qui simplifieraient la démarche.
    "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...
    ---------------

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Retraité
    Inscrit en
    Juin 2021
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Retraité
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Juin 2021
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    En fait il suffisait d'inclure un "=" :
    Sheets("Event").ComboBox1.ListFillRange = Sheets("Inscriptions").Range("=XFC1:XFD" & RColCombo)

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 764
    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 : 12 764
    Points : 28 622
    Points
    28 622
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    En fait il suffisait d'inclure un "=" :
    Sheets("Event").ComboBox1.ListFillRange = Sheets("Inscriptions").Range("=XFC1:XFD" & RColCombo)
    Vous êtes certain que cela fonctionne ?
    Sauf erreur de ma part, la propriété ListFillRange est de type String donc d'après moi, il manque la propriété Address à l'objet Range

    Petite illustration rapide
    Le code ci-dessous, fonctionne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Worksheet_Activate()
      With Me.ComboBox1
      .ListFillRange = Me.Range("A2:C30").Address
      End With
    End Sub
    Alors que .ListFillRange = Me.Range("A2:C30") renverra une erreur
    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

  5. #5
    Responsable
    Office & Excel


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

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

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 924
    Points
    55 924
    Billets dans le blog
    131
    Par défaut
    Salut Philippe,

    Tout à fait. Mais il faut noter que Me.Range("A2:C30").Address pointera vers la feuille active. Il conviendra donc que dumphi51 préfixe l'adresse du nom de la feuille. Dans la mesure où le combobox s'appuie "forcément" sur une table de données, je ne saurais trop lui conseiller de travailler avec un tableau structuré et la propriété List du combo => Combobox1.List = range("MonTableau").value, par exemple...
    "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...
    ---------------

  6. #6
    Futur Membre du Club
    Homme Profil pro
    Retraité
    Inscrit en
    Juin 2021
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Retraité
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Juin 2021
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    Merci pour votre aide et vous vos méthodes sont certainement plus correctes et je testerais encore aujourd'hui. Néanmoins le code suivant fonctionne :

    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
    Sub FCombo()
     
        Dim i As Integer
     
        Sheets("Event").Select
        Sheets("Event").Unprotect
            'Sheets("Event").ComboBox1.Clear
     
        LColCombo = Sheets("Inscriptions").Cells(6, Columns.Count).End(xlToLeft).Column
        j = 1
     
        For i = 7 To LColCombo Step 3
           Range("X" & j) = Sheets("Inscriptions").Cells(6, i)
           Range("Y" & j) = Sheets("Inscriptions").Cells(3, i)
        j = j + 1
        Next
     
        RColCombo = Cells(Rows.Count, "X").End(xlUp).Row
     
        Sheets("Event").ComboBox1.ListFillRange = "=X1:Y" & RColCombo
     
     
    End Sub
    Bien à voue et bon dimanche

  7. #7
    Responsable
    Office & Excel


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

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

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 924
    Points
    55 924
    Billets dans le blog
    131
    Par défaut
    Sheets("Event").ComboBox1.ListFillRange = "=X1:Y" & RColCombo
    Pile poil ce qu'expliquait Philippe ^^
    "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...
    ---------------

  8. #8
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 764
    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 : 12 764
    Points : 28 622
    Points
    28 622
    Billets dans le blog
    53
    Par défaut
    Bonjour Pierre,
    Mais il faut noter que Me.Range("A2:C30").Address pointera vers la feuille active. Il conviendra donc que dumphi51 préfixe l'adresse du nom de la feuille. Dans la mesure où le combobox s'appuie "forcément" sur une table de données, je ne saurais trop lui conseiller de travailler avec un tableau structuré
    Je suis entièrement d'accord avec toi. J'ai écrit une réponse rapide pour mettre le doigt sur le fait que cela ne pouvait fonctionner comme l'initiateur de la discussion l'affirmait.

    L'idéal, étant d'ajouter évidemment l'argument External avec comme valeur True pour éviter les problèmes pour le cas fort probable où la source de données du ComboBox se trouverait sur une autre feuille
    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

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

Discussions similaires

  1. Renseigner des ListBox/ComboBox multi-colonnes - Récupérer la sélection
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 07/09/2007, 13h42
  2. [VB.NET]ComboBox Multi-Colonnes
    Par Golzinne dans le forum Windows Forms
    Réponses: 3
    Dernier message: 02/03/2006, 18h55
  3. Combobox à plusieurs colonnes
    Par valval dans le forum Composants VCL
    Réponses: 3
    Dernier message: 14/02/2006, 02h36
  4. Affichage ComboBox multi-colonnes
    Par dough29 dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 04/12/2005, 12h28

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