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

Windows Forms Discussion :

Trier une Listview (Colonne numérique/ Date)


Sujet :

Windows Forms

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    923
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 923
    Points : 760
    Points
    760
    Par défaut Trier une Listview (Colonne numérique/ Date)
    Bonjour à tous,

    J'ai fait une listview avec 3 colonnes, parmi lesquelles une colonne numérique.
    Pour faire le faire trier (en cliquant sur des colonnes), j'ai utilise le code disponible dans le FAQ. Le seule soucis c'est qu'il marche bien pour des donnés Alpha, mais pas pour des numériques (sauf si j'écris 001, 010 et 100, par exemple)

    J'essaye donc d'avoir les donnés numériques de ma première colonne au format "###", et lorsque quelqu'un faisse un clic, je voudrais changer le format de cette collone à "000", faire le tri et après revenir à "###".

    Je pense que ça soit une bonne idée, mais je n'arrive pas à changer le format de la colonne.

    Est-ce que quelqu'un peut m'aider à le faire, svp?
    Merci d'avance.

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    923
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 923
    Points : 760
    Points
    760
    Par défaut
    C'est fait.

    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
       Private Sub lstCollaborateurs_ColumnClick(ByVal sender As Object, ByVal e As System.Windows.Forms.ColumnClickEventArgs) Handles lstCollaborateurs.ColumnClick
            For i = 0 To lstCollaborateurs.Items.Count - 1
                lstCollaborateurs.Items(i).SubItems(0).Text = Format(Val(lstCollaborateurs.Items(i).SubItems(0).Text), "000")
            Next
     
            If Me.lstCollaborateurs.Sorting = SortOrder.Ascending Then
                Me.lstCollaborateurs.Sorting = SortOrder.Descending
            Else
                Me.lstCollaborateurs.Sorting = SortOrder.Ascending
            End If
            Me.lstCollaborateurs.ListViewItemSorter = New ListViewItemComparer(e.Column, Me.lstCollaborateurs.Sorting)
     
            For i = 0 To lstCollaborateurs.Items.Count - 1
                lstCollaborateurs.Items(i).SubItems(0).Text = Format(Val(lstCollaborateurs.Items(i).SubItems(0).Text), "###")
            Next
        End Sub

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    923
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 923
    Points : 760
    Points
    760
    Par défaut
    Après avoir reussi à trier des colonnes numériques, j'ai des soucis pour des dates:

    J'essaye la même logique (j'ai trouvé le code ici):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For i = 1 To ListView1.Items.Count-1
        ListView1.Items(i).SubItems(3).Text = CDec(CDate(ListView1.Items(i).SubItems(3).Text))
        Next
    Mais j'ai l'erreur
    "Value of type 'Date' cannot be converted to 'Decimal'."

    Pourquoi ça ne marche pas??


    Merci d'avance

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    923
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 923
    Points : 760
    Points
    760
    Par défaut
    J'ai trouvé la solution, en changeant le format du champ date:

    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
    Temps = 0
            For i = 0 To Me.lstFormations.Items.Count - 1
                If Me.lstFormations.Items(i).SubItems(3).Text = "-" Then
                    Me.lstFormations.Items(i).SubItems(3).Text = "31/12/3010"
                    Me.lstFormations.Items(i).SubItems(3).Text = CDate(Me.lstFormations.Items(i).SubItems(3).Text)
                End If
                Me.lstFormations.Items(i).SubItems(3).Text = Format(CDate(Me.lstFormations.Items(i).SubItems(3).Text), "yyyy-MM-dd")
            Next
     
            If Me.lstFormations.Sorting = SortOrder.Ascending Then
                Me.lstFormations.Sorting = SortOrder.Descending
            Else
                Me.lstFormations.Sorting = SortOrder.Ascending
            End If
            Me.lstFormations.ListViewItemSorter = New ListViewItemComparer(e.Column, Me.lstFormations.Sorting)
     
            For i = 0 To Me.lstFormations.Items.Count - 1
                Me.lstFormations.Items(i).SubItems(3).Text = Format(CDate(Me.lstFormations.Items(i).SubItems(3).Text), "dd/MM/yyyy")
                If Me.lstFormations.Items(i).SubItems(3).Text = "31/12/3010" Then Me.lstFormations.Items(i).SubItems(3).Text = "-"
            Next

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

Discussions similaires

  1. Comment trier une listview
    Par samgan dans le forum VB.NET
    Réponses: 0
    Dernier message: 28/04/2010, 18h14
  2. Trier un listview sur champ date
    Par codial dans le forum IHM
    Réponses: 6
    Dernier message: 08/12/2009, 17h03
  3. [XL-2003] Trier une période entre 2 dates
    Par Stutak dans le forum Excel
    Réponses: 6
    Dernier message: 03/11/2009, 03h03
  4. Trier une listview
    Par Gaetch dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 17/07/2007, 13h36
  5. Réponses: 7
    Dernier message: 28/01/2007, 11h38

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