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 :

Ignorer les cellules vides dans une combo-box [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Inscrit en
    Septembre 2007
    Messages
    26
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 26
    Points : 18
    Points
    18
    Par défaut Ignorer les cellules vides dans une combo-box
    Bonjour à toutes et à tous.

    Voila j'ai un gros souci que je n'arrive pas à résoudre encore une fois.

    J'ai une interface qui fonctionne très bien (filtrage, userform, etc....)

    Mais voila j'aimerais que mes combobox ignorent les cellules vides dans chaque colonnes sélectionnées.

    Je vous joins un exemple qui vous permettra de bien situé ma demande ainsi que le code de mon userform.

    Merci beaucoup

    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
    34
    35
    36
    Option Base 1
     
    Private Sub UserForm_Initialize()
    Dim LastLig As Long
    Dim j As Long
    Dim i As Byte
    Dim n As Long
    Dim ColCrit
    Dim hWnd As Long
     
    ColCrit = Array(1, 2, 3, 4, 5, 6)
     
    With Sheets("exemple")
         .AutoFilterMode = False
            For i = 1 To UBound(ColCrit)  
                LastLig = .Cells(.Rows.Count, ColCrit(i)).End(xlUp).Row
            For j = 3 To LastLig
                Me.Controls("ComboBox" & i).Value = .Cells(j, ColCrit(i)).Value
            If Me.Controls("ComboBox" & i).ListIndex = -1 Then Me.Controls("ComboBox" & i).AddItem .Cells(j, ColCrit(i)).Value 
                Me.Controls("ComboBox" & i).ListIndex = -1
            Next j
    With Me.Controls("ComboBox" & i)
                                           For x = 0 To .ListCount - 1 
                                                           For y = 0 To .ListCount - 1
     
            If .List(x) < .List(y) Then
                strTemp = .List(x)
                            .List(x) = .List(y) 
                                .List(y) = strTemp
     
    End If
        Next y
            Next x
                End With
                    Next i
                        End With
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    BOnjour Esak59,

    Je n'ai pas pris la peine de télécharger ton fichier mais j'ai modifié ton code. Je pense que pour une meilleure lisibilité de ce dernier tu devrais adopter la façon de coder qu'ont les personnes ici à savoir incrémenter ton code, l'aérer et surtout, le commenter car ça facilite sa maintenance. J'ai supprimé ton tableau "ColCrit" car il ne sert à rien puisque les valeur se suivent de 1 à 6 :
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
     
    Private Sub UserForm_Initialize()
     
        Dim LastLig As Long
        Dim J As Long
        Dim I As Byte
        Dim n As Long
        Dim hWnd As Long
     
        With Sheets("exemple")
            .AutoFilterMode = False
     
            'parcour les colonnes de A à F
            For I = 1 To 6
                'en recherche le n° de ligne de la dernière cellule non vide
                LastLig = .Cells(.Rows.Count, I).End(xlUp).Row
     
                'parcour les cellules de chaque colonnes
                For J = 3 To LastLig
     
                    'évite les cellules vides
                    If .Cells(J, I) <> "" Then
     
                        'affecte la valeur au combo concerné
                        Me.Controls("ComboBox" & I).Value = .Cells(J, I).Value
     
                        'si elle n'existe pas la rajoute
                        If Me.Controls("ComboBox" & I).ListIndex = -1 Then
                            Me.Controls("ComboBox" & I).AddItem .Cells(J, I).Value
                        End If
     
                        Me.Controls("ComboBox" & I).ListIndex = -1
     
                    End If
     
                Next J
     
                'effectue un tri croissant dans le combo
                With Me.Controls("ComboBox" & I)
     
                    For x = 0 To .ListCount - 1
     
                        For y = 0 To .ListCount - 1
     
                            If .List(x) < .List(y) Then
                                strTemp = .List(x)
                                .List(x) = .List(y)
                                .List(y) = strTemp
     
                            End If
     
                        Next y
     
                    Next x
     
                End With
     
            Next I
     
        End With
     
    End Sub
    Hervé.

  3. #3
    Membre à l'essai
    Inscrit en
    Septembre 2007
    Messages
    26
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 26
    Points : 18
    Points
    18
    Par défaut
    Bonjour à toutes et à tous

    Désolé pour cette réponse tardive.

    J'ai adapter ton code, à mon projet car le fichier que le code que j'ai posté était à titre d'exemple.

    Donc après quelques retouches par ici et par là, j'ai réussi à l'adapter comme il se doit.

    Merci à toi encore Theze, pour toutes ces explications.

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

Discussions similaires

  1. [Oracle] Ignorer les champs vides dans une requête sql
    Par roswina dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 26/05/2015, 09h29
  2. [XL-2013] Comment intégrer tous les noms de plages nommées d'un classeur dans une combo box?
    Par Xilian dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 25/01/2015, 13h17
  3. Remplir les cellules vides dans une boucle
    Par zoltar_x dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 27/11/2011, 18h35
  4. Réponses: 14
    Dernier message: 01/07/2009, 13h49
  5. Modif d'un ini dans une combo box
    Par Julien.alkaza dans le forum C++Builder
    Réponses: 5
    Dernier message: 03/04/2005, 23h39

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