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 :

Criteres de selection [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    retraite
    Inscrit en
    Avril 2010
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Espagne

    Informations professionnelles :
    Activité : retraite
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2010
    Messages : 325
    Par défaut Criteres de selection
    bonjour
    je cherche a tri ma listview avec un combobox.

    voici mon code:
    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
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    Code Visual Basic :
     
    Private Sub CommandButton1_Click()
    Me.Hide
    Sheets("Menu").Select
    End Sub
     
    Private Sub Barbecue_Click()
     Load Barbecues
     Barbecues.Show
     Unload UserForm1
     UserForm1.Show
     Sheets("Menu").Select
    End Sub
     
     
    Private Sub Retour_Menu_Click()
     Sheets("Menu").Select
     Range("P5").Select
     Application.DisplayFormulaBar = False
     Unload UserForm1
     End Sub
     
    Private Sub TextBox1_Change()
    Me.TextBox1 = Sheets("Barbecue").Range("I2")
    End Sub
    Private Sub userform_activate()
     
     Sheets("Barbecue").Select
     Application.DisplayFullScreen = True
     
     TextBox1.Value = Sheets("Barbecue").Range("I2").Value
     
     
     
    With Me
    .StartUpPosition = 3
    .Width = Application.Width
    .Height = Application.Height
    .Left = 0
    .Top = 0
    End With
     
    'Suppression des titres de colonnes
    ListView1.ColumnHeaders.Clear
     
    'Alimentation des titres de colonne :
     
    ListView1.ColumnHeaders.Add , , "Mois", ListView1.Width * 0.1, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Nom", ListView1.Width * 0.22, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Nº MobilHome", ListView1.Width * 0.15, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Duree", ListView1.Width * 0.1, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Reglement", ListView1.Width * 0.12, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Prix Location", ListView1.Width * 0.13, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Total", ListView1.Width * 0.08, lvwColumnRight
    ListView1.ColumnHeaders.Add , , "Caution", ListView1.Width * 0.1, lvwColumnCenter
     
    'on remplit la listview
     
    With Me.ListView1
    .ListItems.Clear
        For Each V In Range("A4:A" & Range("A65536").End(xlUp).Row)
            X = X + 1
            .ListItems.Add , , V.Text
            .ListItems(X).ForeColor = V.Font.Color
     
            For j = 1 To 8
                .ListItems(X).ListSubItems.Add , , V.Offset(0, j).Text
                .ListItems(X).ListSubItems(j).ForeColor = V.Offset(0, j).Font.Color
     
            Next j
    Next V
    End With
     
    End Sub


    a l'aide d'un combobox ou j'ai une liste des mois de l'annee
    apres choix dans ce comboboxavoir l'affichage du mois choisi ainsi que ses donnees
    dans le combobox
    Tous les mois
    Janvier
    Février
    Mars
    etc...

    cris

  2. #2
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 128
    Par défaut
    Salut

    Je suppose qu'une fois un mois choisi dans ta ComboBox, tu souhaites n'afficher dans le listBox que les données correspondante au mois sélectionné?
    Si c'est bien ça dis nous dans quelle colonne de ton tableau le mois apparaît-il?

    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  3. #3
    Membre éclairé
    Homme Profil pro
    retraite
    Inscrit en
    Avril 2010
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Espagne

    Informations professionnelles :
    Activité : retraite
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2010
    Messages : 325
    Par défaut
    c'est exactement cela, dans ma listview
    dans la colonne A, et le debut des mois commence en A4.

  4. #4
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 128
    Par défaut
    Salut

    Alors quelque chose comme ça devrait faire l'affaire (pas testé)

    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
    With Me.ListView1
        .ListItems.Clear
        For Each V In Range("A4:A" & Cells(Rows.Count, "A").End(xlUp).Row)
            'Ici on controle que le mois inscrit dans la tableau Excel correspond bien au moi choisi
            'Si aucun moi n'a été choisi, on inscrit toutes les données
            If (V.Value = ComboBox1.Text) Or (ComboBox1.Text = "") Then
                'On ajoute une ligne
                With .ListItems.Add(, , V.Text)
                    .ForeColor = V.Font.Color
                    For j = 1 To 8
                        .ListSubItems.Add , , V.Offset(0, j).Text
                        .ListSubItems(j).ForeColor = V.Offset(0, j).Font.Color
                    Next j
                End With
            End If
        Next V
    End With
    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  5. #5
    Membre éclairé
    Homme Profil pro
    retraite
    Inscrit en
    Avril 2010
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Espagne

    Informations professionnelles :
    Activité : retraite
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2010
    Messages : 325
    Par défaut
    j'ai beau mettre n'importe quels mois , cela ne fonctionne pas.
    la listview reste en etat
    ci joint mon fichier
    cris
    Fichiers attachés Fichiers attachés

  6. #6
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 128
    Par défaut
    Salut

    Dans ta Combobox tu as Janvier, Fevrier, Mars...
    Et dans ta colonne A tu as quoi exactement?
    [Edit]
    Je viens de voir ton fichier, je regarde[/Edit]


    ++
    Qwaz

    Salut

    Alors voila les modifications, lit bien les commentaires, il y a des propriétés de certains composants à modifier.

    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
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    Private Sub ComboBox1_Change()
    'On met a jour la liste
    MaJList
    End Sub
     
    Private Sub TextBox1_Change()
    'Inutile il suffit de passer sa propriété Enabled à False
    'Me.TextBox1 = Sheets("Barbecue").Range("I2")
    End Sub
    Private Sub userform_activate()
    ' Sheets("Barbecue").Select
    'Application.DisplayFullScreen = True 'désactiver pour les essais
     
    'With Me
    '    .StartUpPosition = 3
    '    .Width = Application.Width
    '    .Height = Application.Height
    '    .Left = 0
    '    .Top = 0
    'End With
     
     
    'Autant lier le textbox à la cellule I2
    'Regarde dans les propriété du TextBox (ControlSource) et met comme valeur Barbecue!I2
    'Regardes également la propriété Enabled du TextBox qui interdit la modification du contenu (met la False)
    'TextBox1.Value = Sheets("Barbecue").Range("I2").Value
     
    'On selectionne la 1er entré de la combobox "Tous les mois"
    ComboBox1.ListIndex = 0 'La liste est mise a jour (execution de ComboBox1_Change())
     
     
    End Sub
     
    Sub MaJList()
     
    'Dans les propriété de ta ComboBox, met Style à fmStyleDropDownList, sa interdit à l'utilisateur de pouvoir taper n'importequoi
    Dim ShBarbeuc As Worksheet
    'On pointe sur la feuille Barbecue
    Set ShBarbeuc = ThisWorkbook.Sheets("Barbecue")
     
    'Suppression des titres de colonnes
    ListView1.ColumnHeaders.Clear
     
    'Alimentation des titres de colonne :
    'Ton fichier à planté au chargement et m'a viré le listView, je ne peux donc pas verifier ce que tu as mis comme propriété
    'Mais tu doit avoir la propriété View à lvwReport
     
    ListView1.ColumnHeaders.Add , , "Mois", ListView1.Width * 0.1, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Nom", ListView1.Width * 0.22, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Nº MobilHome", ListView1.Width * 0.15, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Duree", ListView1.Width * 0.1, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Reglement", ListView1.Width * 0.12, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Prix Location", ListView1.Width * 0.13, lvwColumnLeft
    ListView1.ColumnHeaders.Add , , "Total", ListView1.Width * 0.08, lvwColumnRight
    ListView1.ColumnHeaders.Add , , "Caution", ListView1.Width * 0.1, lvwColumnCenter
     
     
    With Me.ListView1
        .ListItems.Clear
        For Each V In ShBarbeuc.Range("A4:A" & ShBarbeuc.Cells(Rows.Count, "A").End(xlUp).Row)
            'Ici on controle que le mois inscrit dans la tableau Excel correspond bien au moi choisi
            'Si aucun moi n'a été choisi, on inscrit toutes les données
            'On passe les valeur en majuscule Ucase) pour ne pas etre dérangé par les majuscule en début de nom
            'Décembre n'est pas égale à décembre
            If (UCase(V.Text) = UCase(ComboBox1.Text)) Or (ComboBox1.Text = "Tous les mois") Then
                'On ajoute une ligne
                With .ListItems.Add(, , V.Text)
                    .ForeColor = V.Font.Color
                    For j = 1 To 8
                        .ListSubItems.Add , , V.Offset(0, j).Text
                        .ListSubItems(j).ForeColor = V.Offset(0, j).Font.Color
                    Next j
                End With
            End If
        Next V
    End With
     
    End Sub
    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

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

Discussions similaires

  1. Criteres de selection multiple pour affichage TB
    Par Bichon Taigama dans le forum Excel
    Réponses: 0
    Dernier message: 14/03/2015, 07h26
  2. Réponses: 2
    Dernier message: 19/11/2008, 08h46
  3. Réponses: 4
    Dernier message: 11/11/2008, 12h14
  4. plusieurs selections selon sur colonne different critere
    Par richton95 dans le forum Requêtes
    Réponses: 2
    Dernier message: 27/01/2006, 17h25
  5. critere de selection pr faire un UPDATE sur 1 table
    Par maxizoo dans le forum Langage SQL
    Réponses: 6
    Dernier message: 05/01/2006, 15h35

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