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 :

affichage dans une listview [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé Avatar de grisan29
    Homme Profil pro
    ouvrier poseur
    Inscrit en
    Octobre 2006
    Messages
    866
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ouvrier poseur
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 866
    Points : 520
    Points
    520
    Par défaut affichage dans une listview
    bonjour a vous
    dans l'image que je joint et dont voici le 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
    Private Sub UserForm_Activate()
     
      UserForm1.Caption = "Sélection d'un article"
    '======================================================
     
    Worksheets("Feuil1").Activate
    ActiveSheet.Cells.Columns.AutoFit ' Pour une Largeur cohérente des Colonnes de la Feuille!
     
    With UserForm1.ListView1: .View = 3: .Gridlines = True: .FullRowSelect = True: .Sorted = True
      With .ColumnHeaders
         For i = 1 To 10 '"10" étant un nombre forfaitaire de Colonnes renseignées .... On peut l'adapter!
              If ActiveSheet.Cells(1, i).Value <> "" Then
                 .Add , , ActiveSheet.Cells(1, i).Value, (ActiveSheet.Columns(i).ColumnWidth * 4) + 18
                  '"4" étant issu des tests (Voire Inches et Points), et "+ 18" un correctif de la même origine.
              End If
         Next i
      End With
           For i = 2 To ActiveSheet.Cells(65536, 1).End(xlUp).Row
            .ListItems.Add , , ActiveSheet.Cells(i, 1).Value
                For j = 1 To .ColumnHeaders.Count - 1
                    If ActiveSheet.Cells(i, j + 1).Value <> "" Then
                       .ListItems(.ListItems.Count).ListSubItems.Add , , ActiveSheet.Cells(i, j + 1).Value
                    Else
                       .ListItems(.ListItems.Count).ListSubItems.Add , , "?" 'Ceci pour une suite où Wind n'aime pas le vide!
                    End If
                Next j
          Next i
    End With
    End Sub
    comment faire pour que la listview soit rangé par ordre descendant et non par dizaine ou centaine

    merci par avance

    cordialement

    Pascal

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

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

    Informations forums :
    Inscription : Avril 2002
    Messages : 3 906
    Points : 8 539
    Points
    8 539
    Par défaut
    Salut

    Essai comme cela

    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
    Private Sub UserForm_Activate()
    Dim SheetBase As Worksheet
    UserForm1.Caption = "Sélection d'un article"
    '======================================================
    'Inutile de l'activer,on pointe juste dessus
    Set SheetBase = Thisworkbook.sheets("Feuil1")
     
    SheetBase.Cells.Columns.AutoFit ' Pour une Largeur cohérente des Colonnes de la Feuille!
     
    With UserForm1.ListView1: .View = 3: .Gridlines = True: .FullRowSelect = True: .Sorted = True
        With .ColumnHeaders
            For i = 1 To 10 '"10" étant un nombre forfaitaire de Colonnes renseignées .... On peut l'adapter!
                 If SheetBase.Cells(1, i).Value <> "" Then
                    .Add , , SheetBase.Cells(1, i).Value, (SheetBase.Columns(i).ColumnWidth * 4) + 18
                     '"4" étant issu des tests (Voire Inches et Points), et "+ 18" un correctif de la même origine.
                 End If
            Next i
        End With
     
        For i = 2 To SheetBase.Cells(SheetBase.Rows.Count, 1).End(xlUp).Row
            'On format la valeur sur 3 chiffres
            .ListItems.Add , , Format(SheetBase.Cells(i, 1).Value, "00#")
            For j = 1 To .ColumnHeaders.Count - 1
                If SheetBase.Cells(i, j + 1).Value <> "" Then
                   .ListItems(.ListItems.Count).ListSubItems.Add , , SheetBase.Cells(i, j + 1).Value
                Else
                   .ListItems(.ListItems.Count).ListSubItems.Add , , "?" 'Ceci pour une suite où Wind n'aime pas le vide!
                End If
            Next j
        Next i
    End With
    End Sub
    J'en ai profité pour supprimer ActiveSheet.

    ++
    Qwaz

  3. #3
    Membre confirmé Avatar de grisan29
    Homme Profil pro
    ouvrier poseur
    Inscrit en
    Octobre 2006
    Messages
    866
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ouvrier poseur
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 866
    Points : 520
    Points
    520
    Par défaut MERCI
    bonjour Qwazerty

    un grands Merci cela marche a merveille

    cordialement

    Pascal

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

Discussions similaires

  1. Affichage dans une listview
    Par porto53 dans le forum VB.NET
    Réponses: 1
    Dernier message: 06/06/2012, 08h31
  2. Problème d'affichage dans une ListView
    Par tabbabi dans le forum Composants graphiques
    Réponses: 2
    Dernier message: 10/08/2011, 12h58
  3. Affichage d'images dans une listView
    Par kyria dans le forum C#
    Réponses: 1
    Dernier message: 16/10/2010, 00h35
  4. affichage des données d'une bd dans une listview
    Par SALIA LOUA OLIVIER dans le forum VB.NET
    Réponses: 5
    Dernier message: 13/07/2010, 18h02
  5. Réponses: 8
    Dernier message: 12/05/2006, 14h04

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