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 :

Probleme de transfere d'une listebox a une autre


Sujet :

VB.NET

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Réunion

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2013
    Messages : 60
    Points : 30
    Points
    30
    Par défaut Probleme de transfere d'une listebox a une autre
    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
        Private Sub TransfertListe(ByVal L1 As ListBox, ByVal L2 As ListBox)
            Dim Item As Object
            Dim I As Integer
     
            'Ajouter les éléments sélectionnés dans L1 à L2
            For Each Item In L1.SelectedItems
                L2.Items.Add(Item)
            Next
     
            'Supprimer les éléments sélectionnés dans L1
            'en commençant par le dernier élément.
            For I = L1.SelectedIndices.Count - 1 To 0 Step -1
                L1.Items.RemoveAt(L1.SelectedIndices(I))
            Next
     
            AfficherNbrElements(L1, L2)
        End Sub
    L'erreur intervient a la ligne 13 : "Impossible de modifier la collection d'éléments lorsque la propriété DataSource est définie."

    Effectivement voici comment se remplie ma liste box :
    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
      Dim MyCommand1 As SqlCommand = MyConnexion.createCommand()
                Dim strsql As String
                strsql = "SELECT [NumV],[DescrV] FROM [PPE6_G1].[dbo].[Vaccin];"
     
                MyCommand1.CommandText = strsql
     
                Dim myreader1 As SqlDataReader = MyCommand1.ExecuteReader()
                Dim dt As New DataTable
                dt.Columns.Add("Num")
                dt.Columns.Add("Descript")
     
                Do While myreader1.Read
                    Dim v1 = myreader1.Item(0)
                    Dim v2 As String = myreader1.GetString(1)
                    dt.Rows.Add(v1, v2)
                Loop
                myreader1.Close()
                LtBVaccin.DataSource = dt
                LtBVaccin.DisplayMember = "Descript"
                myreader1.Close()
    Et apres avoir transferer les items d'un box a un autre je veux les inserer :
    Pour chaque item dans la liste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
      Dim requete1 As SqlCommand = MyConnexion.CreateCommand()
                    requete1.CommandText = " select max(NumPers) from Personne;"
                    Dim nb As Integer = requete1.ExecuteScalar()
     
                    Dim requete2 As SqlCommand = MyConnexion.CreateCommand()
                    Dim dv As DataRowView = CType(Me.LtBVaccinChoix.SelectedItem, DataRowView)
                    Dim strsql As String
                    For Each Vaccin As Integer In LtBVaccinChoix.Items
                        strsql = "INSERT INTO Necessiter(NPays_Pays,NumV_Vaccin) VALUES(" & nb & "," & Vaccin & ");"
                        requete2.CommandText = strsql
                        Dim reultat = requete2.ExecuteScalar()
                    Next

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

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    l'erreur est claire

    si tu utilises datasource pour remplir un listbox, c'est datasource qu'il faut modifier pour supprimer (ou autre action) des éléments

    si tu passes par items.Add, tu auras le droit de faire items.remove
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Réunion

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2013
    Messages : 60
    Points : 30
    Points
    30
    Par défaut
    Citation Envoyé par Pol63 Voir le message
    l'erreur est claire

    si tu utilises datasource pour remplir un listbox, c'est datasource qu'il faut modifier pour supprimer (ou autre action) des éléments

    si tu passes par items.Add, tu auras le droit de faire items.remove
    Pourrait tu me donner un exemple ?

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

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    un exemple de quoi ? ca me parait explicite ce que j'ai dit

    tu mets un datatable dans le listbox, si tu veux supprimer une ligne du listbox, soit tu supprimes la ligne du datatable (et voir s'il y a quelquechose à appeler pour resynchroniser le listbox)
    soit tu faire un for each dans le datatable.rows pour faire des .items.add dans le listbox (surement mieux vu que tu as une méthode générique pour traiter les transfert entre listbox)
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

Discussions similaires

  1. Réponses: 4
    Dernier message: 04/04/2011, 11h46
  2. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  3. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  4. [XL-2007] Afficher une checkbox dans une feuille si une checkbox d'une autre feuille est cochée
    Par JessieCoutas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/08/2009, 13h35
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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