Das ListView-Control - ein Steuerelement, welches aufgrund seiner vielfältigen Einsatzmöglichkeit sehr häufig in den eigenen Projekten verwendet wird (ich glaub', ich wiederhole mich da immer wieder - aber es ist halt so - bietet so einiges, doch leider fehlen meiner Meinung nach zwei sehr wichtige Funktionen: a) Speichern des gesamten Daten-Inhaltes Und weil wir ja alle Visual Basic Programmierer sind, proggen wir uns eben diese beiden Funktionen eben selbst Speichern der ListView-Daten ' ListView: Inhalt in eine Datei speichern Public Sub lvw_WriteData(lvw As ListView, _ sDataFile As String) Dim F As Integer Dim intCols As Integer Dim I As Integer Dim U As Integer ' Datei öffnen (ggf. überschreiben) F = FreeFile Open sDataFile For Output As #F ' Anzahl Spalten im ListView intCols = lvw.ColumnHeaders.Count ' ListView zeilenweise speichern With lvw.ListItems For I = 1 To .Count With lvw.ListItems(I) ' als erstes wird der Key-Wert gespeichert Print #F, .Key; vbTab; ' dann wird der Text der 1. Spalte gespeichert Print #F, .Text; ' Jetzt alle weiteren Spalten-Inhalte For U = 1 To intCols - 1 Print #F, vbTab; .SubItems(U); Next U ' Zeilenvorschub Print #F, "" End With Next I End With ' Datei schliessen Close #F End Sub Einlesen und Anzeigen gespeicherter Daten ' ListView: Inhalt aus Datei einlesen und anzeigen ' bAppend gibt an, ob der Inhalt angefügt (True) ' oder das ListView vorher gelöscht werden soll (False) Public Sub lvw_ReadData(lvw As ListView, _ ByVal sDataFile As String, _ Optional ByVal bAppend As Boolean = False) Dim F As Integer Dim sLine As String Dim sItem() As String Dim intCols As Integer Dim I As Integer Dim itemX As ListItem ' ListView löschen (falls bAppend = False) If Not bAppend Then lvw.ListItems.Clear ' Existiert die Datei überhaupt? If Dir(sDataFile, vbNormal) <> "" Then ' Anzahl Spalten im ListView intCols = lvw.ColumnHeaders.Count ' Datei zum Lesen öffnen F = FreeFile Open sDataFile For Input As #F ' Inhalt zeilenweise auslesen With lvw.ListItems While Not EOF(F) Line Input #F, sLine ' Zeile in die einzelnen Spalten zerlegen sItem = Split(sLine, vbTab) ' Falls die Anzahl Datenspalten nicht mit der ' Anzahl Spalten im ListView übereinstimmen, ' -> Array "zurechtrücken" If UBound(sItem) <> intCols Then ReDim Preserve sItem(intCols) End If ' 1. Eintrag (sItem(0)) enthält den Key-Wert Set itemX = .Add(, sItem(0), sItem(1)) ' Jetzt aller "SubItems"-Daten hinzufügen For I = 2 To intCols itemX.SubItems(I - 1) = sItem(I) Next I Wend End With ' Datei schliessen Close #F End If End Sub Anwendungsbeispiel Private Sub Form_Load() ' ListView-Daten lesen lvw_ReadData ListView1, App.Path & "\Adressen.dat" End Sub Beim Beenden der Form wird dann der aktuelle Inhalt des ListView-Controls gespeichert: Private Sub Form_Unload(Cancel As Integer) ' ListView-Daten speichern lvw_WriteData ListView, App.Path & "\Adressen.dat" End Sub Ach ja, noch etwas. Am besten Sie fügen die beiden "neuen" Funktionen in ein Modul Ihres Projekts ein, da Sie dann jederzeit Zugriff auf die beiden Funktionen haben, egal welche Form gerade aktiv ist. Es soll ja vorkommen, dass eine Anwendung mehrere ListView-Controls enthält Dieser Tipp wurde bereits 30.793 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
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. |
TOP! Unser Nr. 1 Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
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. |