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 |