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.438 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. |
sevAniGif (VB/VBA) Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung 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. |