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 :

Alimenter une listbox avec les données d'une feuille par ordre décroissant [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Gestionnaire de parc micro-informatique
    Inscrit en
    Mars 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Gestionnaire de parc micro-informatique

    Informations forums :
    Inscription : Mars 2015
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Alimenter une listbox avec les données d'une feuille par ordre décroissant
    Bonjour,

    Mon problème est simple,
    je suis déjà parvenu à alimenter une listBox avec les données d'une feuille grace au code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub UserForm_Activate()
        Sheets("Log").Select
        ListBox1.List = Range("A2:M" & Cells(Application.Rows.Count, 1).End(xlUp).Row).Value
    End Sub
    J'aimerai pouvoir afficher les lignes affichées dans l'ordre décroissant,
    tout en sachant que la colonne A contient des n° de mouvement dans un ordre croissant (A2=1;A3=2;A4=3;A5=4; etc...)

    Comment afficher simplement la liste obtenue à partir du dernier enregistrement?

    Merci d'avance pour vos réponses...

  2. #2
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    Le plus simple est de trier la plage en ordre croissant sur la colonne A, remplir la listbox et re-trier la plage en ordre croissant sur la colonne A

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Sub UserForm_Initialize()
    Dim Plage As Range
     
    Application.ScreenUpdating = False
    With Worksheets("Log")
        Set Plage = .Range("A2:M" & .Cells(.Rows.Count, 1).End(xlUp).Row)
    End With
     
    Plage.Sort key1:=Plage(1, 1), order1:=xlDescending, Header:=xlNo
    ListBox1.List = Plage.Value
    Plage.Sort key1:=Plage(1, 1), order1:=xlAscending, Header:=xlNo
     
    Set Plage = Nothing
    End Sub

  3. #3
    Candidat au Club
    Homme Profil pro
    Gestionnaire de parc micro-informatique
    Inscrit en
    Mars 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Gestionnaire de parc micro-informatique

    Informations forums :
    Inscription : Mars 2015
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Super merci Mercatog !
    C'est fonctionnel

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

Discussions similaires

  1. [Toutes versions] Remplir une ListBox avec les données d'une autre feuille
    Par Valoche37 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 10/01/2012, 16h25
  2. Alimenter un treeview avec les données d'une table
    Par typzea dans le forum VBA Access
    Réponses: 3
    Dernier message: 11/07/2008, 08h20
  3. Réponses: 3
    Dernier message: 18/07/2006, 17h37
  4. Réponses: 12
    Dernier message: 22/06/2006, 12h09
  5. Réponses: 3
    Dernier message: 09/04/2006, 12h58

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