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 :

ListView - Copier uniquement les lignes cochées dans une autre ListView [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut ListView - Copier uniquement les lignes cochées dans une autre ListView
    Bonjour,

    Je débute tout juste en VBA et avec les ListView. Je vous remercie d'avance pour votre aide.

    Dans un UserForm, j'ai créé deux ListView:

    Dans ListView1 je récupère les données d'un onglet Excel et affiche les lignes récupérées ainsi qu'une box à cocher dans la première colonne. Jusqu'ici cela fonctionne sans problème.

    Une fois avoir coché les lignes qui m'intéressent dans ListView1, je souhaite pouvoir copier toutes ces lignes dans ListView2 par action sur un bouton.

    Je pense à ce type de code, mais il me manque la syntaxe... :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub CommandButton1_Click()
    
    For j = 1 To ListView1.ListItems.Count
                If ListView1.ListItems(j).Checked = True Then
    
              "Copier les lignes cochées dans ListView2"
    
            Next j
    End Sub
    Merci pour votre aide!

    Benoit

  2. #2
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Je me suis débrouillé en Copiant les celulles cochées de ListView1 dans un feuillet puis en récupérant les données dans ce feuillet avec ListView2. Ca marche très bien, mais niveau optimisation je ne suis pas sur que ce soit le top.

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    99
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 99
    Points : 67
    Points
    67
    Par défaut
    Tu peux essayer ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Private Sub CommandButton1_Click()
    For j = 1 To ListView1.ListItems.Count
        If ListView1.ListItems(j).Checked = True Then
            With ListView2
                .ListItems.Add , , (ListView1.ListItems(j))
                For i = 1 To ListView1.ListItems(j).ListSubItems.Count
                    .ListItems(.ListItems.Count).ListSubItems.Add , , ListView1.ListItems(j).ListSubItems(i)
                Next i
            End With
        End If
    Next j
    End Sub
    J'ai testé, ça fonctionne.
    Penses à activer la propriété .View = lvwReport dans tes 2 ListView
    En espérant que ça peux encore t'être utile.

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

Discussions similaires

  1. colorer ligne cochée dans une listview
    Par ayarikhaoulakoukou dans le forum VB.NET
    Réponses: 1
    Dernier message: 20/04/2011, 14h03
  2. Réponses: 2
    Dernier message: 21/06/2007, 13h13
  3. Réponses: 8
    Dernier message: 30/11/2006, 18h32
  4. exclure les lignes blanches dans une requêtes
    Par sam01 dans le forum Requêtes
    Réponses: 6
    Dernier message: 03/10/2006, 09h42
  5. Réponses: 4
    Dernier message: 01/10/2006, 15h37

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