Hin und wieder muss man eine Datei "rückwärts" auslesen, bzw. möchte die letzte oder zweitletzte Zeile einer großen Textdatei ermitteln.br>Leider bietet VB keine Möglichkeit direkt anzugeben, eine Textzeile beginnend beim Dateiende (also von hinten anfangend) auszulesen. Mit nachfolgender Funktion ist das aber jetzt möglich. Beispiel: Aufruf: Private Sub Command1_Click() Text2.Text = ReadLastLine(App.Path & "\" & "MyFile.log", _ True, Val(Text1.Text)) End Sub Fügen Sie jetzt noch nachfolgende Funktion ein: ' Bestimmte Zeile einer Textdatei auslesen ' (vom Dateiende beginnend) Public Function ReadLastLine(sFileName As String, _ ByVal bTrimNullString As Boolean, _ Optional ByVal XteLastLine As Long = 0) As String On Error Resume Next Dim F As Integer Dim nFileLen As Long Dim sTempCR As String * 1 Dim sTempLF As String * 1 ' Datei öffnen F = FreeFile Open sFileName For Binary Access Read As #F ' Dateigröße nFileLen = LOF(F) ' x. letzte Zeile lesen Do Until XteLastLine < 0 ReadLastLine = "" Do ' Solange zeilenweise "rückwärts" einlesen, bis ' gewünschte Zeile gefunden Do ' Zeichen lesen nFileLen = nFileLen - 1 Get #F, nFileLen, sTempCR If Err.Number <> 0 Then ' im Fehlerfalle Prozedur verlassen Close #F ReadLastLine = "" Exit Function End If ' Wenn es sich um CR handelt... If sTempCR = vbCr Then ' Prüfen, ob Zeichen davor = LF Get #F, nFileLen + 1, sTempLF If sTempLF = vbLf Then ' innere Schleife beenden Exit Do End If End If If sTempCR <> vbCr And sTempCR <> vbLf Then ' Zeichen in Rückgabewert speichern ReadLastLine = sTempCR & ReadLastLine End If Loop If Not bTrimNullString Or Len(Trim$(ReadLastLine)) > 0 Then Exit Do Loop XteLastLine = XteLastLine - 1 Loop ' Datei schließen Close #F End Function Kurze Erläuterung: Dieser Tipp wurde bereits 22.381 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. |
Neu! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR... |
||||||||||||||||
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. |