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

VB.NET Discussion :

Supprimer lignes vides dans datagridview [Débutant]


Sujet :

VB.NET

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2016
    Messages : 5
    Points : 5
    Points
    5
    Par défaut Supprimer lignes vides dans datagridview
    Bonjour,

    J'ai un datagridview qui est en lien avec un formulaire.
    J'aimerai pouvoir supprimer avec un bouton les lignes vides de mon datagridview.

    Merci pour votre aide

  2. #2
    Membre expert Avatar de jopopmk
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2011
    Messages
    1 856
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 1 856
    Points : 3 570
    Points
    3 570
    Par défaut
    Salut,

    tu peux simplement faire le parcours des DataGridViewRow et quand tu tombes sur une ligne qui n'a pas de valeur pour une colonne définie tu la supprime. Attention toutefois à la ligne d'ajout à la fin si tu as positionné AllowUserToAddRows à true.

    Bon dev.

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2016
    Messages : 5
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    Merci pour ta réponse,
    Mais concrètement, comment je fais le parcours des DataGridViewRow vides ?

    Débutant en Vb et connaissant un peu le vba, j'ai pensé à écrire cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     Dim i As Integer
     For i = 0 To 500
     
     If DataGridView1.Item(0, i).Value = "" And DataGridView1.Item(1, i).Value = "" And DataGridView1.Item(2, i).Value = "" Then
                 DataGridView1.Row(i).Remove(DataGridView1.CurrentRow)
    End if 
    Next
    Mais évidement, cela ne marche pas


    Merci de ton aide.

    cdt

  4. #4
    Membre expert Avatar de jopopmk
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2011
    Messages
    1 856
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 1 856
    Points : 3 570
    Points
    3 570
    Par défaut
    Pense à utiliser les balises CODE pour que tes extraits de code soient plus lisibles

    Alors pour le parcour des Row tu peux pas simplement faire une boucle de 0 à n, car tu ne sais pas si n est ton max. Tu peux soit récupérer ta borne max via l'attribut Count de la collection de Rows, soit utiliser un foreach. Exemple en C# :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    // dgvMem : mon instance de DataGridView
    // ma deuxième colonne est discriminante (cf. Cells[1])
    foreach (DataGridViewRow row in dgvMem.Rows)
    	if (row.Cells[1].Value.ToString() == "")
    		dgvMem.Rows.Remove(row);
    edit : un exemple en VB.NET, qui utilise l'indexeur nommé pour changer (mais tu peux utiliser un index comme au-dessus si tu préfères) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    For Each row As DataGridViewRow In dgvMem.Rows
        If row.Cells.Item("lastname").Value.ToString = "" Then
            dgvMem.Rows.Remove(row)
        End If
    Next
    Bon dev.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2016
    Messages : 5
    Points : 5
    Points
    5
    Par défaut
    Super.
    Merci bcp pour ton aide.
    Cdt

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

Discussions similaires

  1. Supprimer ligne vide dans une grid
    Par Edta dans le forum GWT et Vaadin
    Réponses: 0
    Dernier message: 09/07/2013, 09h34
  2. Supprimer ligne vide dans un sous-formulaire
    Par madjon6 dans le forum Access
    Réponses: 4
    Dernier message: 17/01/2012, 10h58
  3. [WD16] Supprimer lignes vides dans excel
    Par EriCstoFF dans le forum WinDev
    Réponses: 2
    Dernier message: 09/09/2011, 10h34
  4. [AC-2003] supprimer lignes vides dans le code
    Par cluster26 dans le forum VBA Access
    Réponses: 7
    Dernier message: 26/08/2010, 23h35
  5. [WD-2003] Supprimer ligne vide dans tableau
    Par ginaub00 dans le forum Word
    Réponses: 1
    Dernier message: 27/05/2010, 17h09

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