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 :

Recherche de row dans un DataGridView via une textbox [Débutant]


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2012
    Messages : 166
    Par défaut Recherche de row dans un DataGridView via une textbox
    Bonjour à tous,
    Voila je dois créer une recherche dans un datagridview qui ira sélectionner une row.
    Cette recherche devra s'effectuer dans un textbox où je saisie la/les premières lettres.
    En fonction de la quantité des lettres saisies dans la textbox, la recherche s'affine dans le datagridview.
    Par exemple :
    MonDgv contien dans le colonne 2 des noms (martin, arthur, patrick, patrice, martine,...)
    Si dans mon textbox je commence à saisir "mar", MonDgv selectionne la 1ere row(2) qui commence par "mar"...
    Ainsi de suite.
    1) Pour l'instant, j'ai fait une sub qui réalise un boucle (lit tout le dgv et compare le textbox avec le row(2).startwith... Si ok, la row trouvé se sélectionne et exit sub.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        Private Sub TextBox1_TextChanged(sender As Object, e As EventArgs) Handles TextBox1.TextChanged
            For Each row As DataGridViewRow In Lst_Depts.Rows
                If row.Cells(2).Value.ToString.StartsWith(TextBox1.Text) Then
                    row.Selected = True
                    Exit Sub
                End If
            Next
        End Sub
    Je trouve ça un peu lourd en ressource, n'y aurait-il pas un autre moyen plus light ?
    2) bien évidemment, il faudrai que la liste du dgv se recentre sur la sélection car mon dgv a plus de 200 lignes. Bon, là, aucune idée de comment faire... Si vous en avez une, je suis preneur.
    Merci
    Patrick

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    1/
    oui et non
    normalement on essai de ne pas travailler sur les controles, on garde les données qu'on lit dans une collection, on met la collection dans le dgv et on fait des recherches sur la collection
    néanmoins pour 200 lignes (très peu) ca ne pose pas de soucis, et puis pour avoir la ligne dans le dgv ca peut etre plus simple comme ca

    2/
    définir le dgv.currentcell doit ramener la ligne dans la partie visible du scroll
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    Comme dit par Pol, perso je préfère travailler sur ma liste d'objet quitte à réaffecter une liste expurgée au DGV.

    Ca a l'avantage de résoudre le problème du point 2 en même temps.

    Sinon, pour tout de même gérer l'affichage dans le DGV, en utilisant l'intellisense, tu trouveras 4 propriétés qui t'aideront (surtout 2 d'entres-elles).
    Donc dans VS, tu tappes, le nom de ton DGV, tu mets un point et tu tapes "first". Tu trouveras ton bonheur ^^.

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2012
    Messages : 166
    Par défaut
    Merci à tous les 2 pour votre aide.
    @Pol63,
    je ne vois pas comment utiliser le dgv.currentcell
    @Kropernic,
    Merci pour le first...
    Pour la communauté, ci-dessous une part de mon code, bon !! j'en suis pas très fier, mais il fonctionne. Si vous avez un meilleur idée...
    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
        Private Sub TextBox1_TextChanged(sender As Object, e As EventArgs) Handles TextBox1.TextChanged
            For Each row As DataGridViewRow In Lst_Depts.Rows
                ' boucle de recherche sur la colonne 2
                If row.Cells(2).Value.ToString.StartsWith(TextBox1.Text) Then
                    row.Selected = True
                    Try
                        ' afin de ne pas coller la selection sur la 1ere ligne (visible) du dgv -> row.Index - 8
                        Lst_Depts.FirstDisplayedScrollingRowIndex = row.Index - 8
                    Catch ex As Exception
                        ' si error, gérée par ici, afficher normalement la row position par rapport au scroll.
                        Lst_Depts.FirstDisplayedScrollingRowIndex = row.Index
                    End Try
                    Exit Sub
                End If
                ' boucle de recherche sur la colonne 1
                If row.Cells(1).Value.ToString.StartsWith(TextBox1.Text) Then
                    row.Selected = True
                    Try
                        Lst_Depts.FirstDisplayedScrollingRowIndex = row.Index - 8
                    Catch ex As Exception
                        Lst_Depts.FirstDisplayedScrollingRowIndex = row.Index
                    End Try
                    Exit Sub
                End If
            Next
        End Sub
    Merci à tous
    Patrick

  5. #5
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    J'ai une question car je suis curieux.

    Par quoi est peuplé ton DGV ? En clair, que mets-tu dans sa propriété Datasource ?

  6. #6
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dgv.currentcell = row.cells(2)
    non ?

    sinon en effet mettre un try catch pour éviter un plantage si l'index n'existe pas c'est moche, autant vérifier le nombre de ligne, ca sera plus performant et plus propre
    tu as row.index, dgv.rows.count etc... tu dois bien pouvoir faire un if pour éviter ca ...
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

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

Discussions similaires

  1. [Débutant] Changer couleur d'une row dans un Datagridview bindé
    Par jeremyvb11 dans le forum VB.NET
    Réponses: 5
    Dernier message: 13/01/2013, 15h32
  2. Bloquer une seule Row dans un DataGridView
    Par Contrec dans le forum C#
    Réponses: 4
    Dernier message: 05/09/2007, 13h07
  3. Réponses: 5
    Dernier message: 10/11/2006, 11h00
  4. Rechercher un mot dans les enregistrements d'une table access
    Par codial dans le forum Bases de données
    Réponses: 3
    Dernier message: 08/11/2006, 21h35
  5. Mise en forme dans un RTF via une syntaxe personnelle
    Par sqwalichou dans le forum Autres langages
    Réponses: 2
    Dernier message: 24/02/2006, 22h19

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