vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Controls · ListBox & ComboBox   |   VB-Versionen: VB2005, VB200816.01.09
Doppelte Einträge einer (Combo-)Listbox löschen

Eine kleine Funktion, die alle doppelte Einträge innerhalb einer Combo- bzw. ListBox entfernt.

Autor:   Dieter OtterBewertung:  Views:  20.107 
www.tools4vb.deSystem:  Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Wie lässt sich am einfachsten eine Routine erstellen, welche nach doppelten Einträgen innerhalb einer Combo- oder Listbox sucht und diese dann automatisch entfernt?

Eine Möglichkeit wäre die Einträge der Liste in ein String-Array zu kopieren und anschließend mittels einer kleinen Hilfsfunktion alle doppelten Einträge zu entfernen. Das Ergebnis wird dann wieder zurück in die ListBox geschrieben.

With ListBox1.Items
  ' Inhalt der Liste in ein String-Array kopieren
  Dim sItems(.Count - 1) As String
  .CopyTo(sItems, 0)
 
  ' ListBox löschen
  .Clear()
 
  ' doppelte Einträge aus dem Array entfernen und 
  ' Array zurück in die ListBox schreiben
  .AddRange(DestinctArray(Of String)(sItems))
End With
' Diese Funktion stammt aus dem Tipp:
' Doppelte Werte bei Ausgabe eines Arrays unterdrücken
Private Function DestinctArray(Of T)(ByVal arr() As T) As T()
  Dim tList As New List(Of T)
  For Each i As T In arr
    If Not tList.Contains(i) Then
      tList.Add(i)
    End If
  Next
  Return tList.ToArray
End Function



Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.