Immer wieder taucht die Frage auf, wie man schnell die Anzahl der Zeilen einer Textdatei ermitteln kann. Viele User gehen hierbei den "einfachsten" Weg, indem Sie die Textdatei öffnen den gesamten Inhalt auslesen und diesen in ein String-Array packen, um anschließend die Größe des Arrays abzufragen: Dim Lines As String() = My.Computer.FileSystem.ReadAllText( _ Filename, System.Text.Encoding.Default).Split(vbCr) Dim LineCount As Integer = Lines.Length Diese Methode funktioniert zwar zuverlässig, benötigt für große Dateien mit mehreren MegaBytes an Daten jedoch "zu viel" Zeit. Nachfolgend möchte ich eine Funktion vorstellen, mit der sich die Anzahl der Zeilen um ein Vielfaches schneller ermitteln lässt. Die Datei wird hierbei blockweise in ein Byte-Array ausgelesen, wobei bei jedem Block-Lesevorgang dann die Anzahl der Umbruchzeichen in dem gelesen Byte-Arrayblock ermittelt werden. ''' <summary> ''' Ermittelt schnell die Anzahl Zeilen einer großen Textdatei ''' </summary> ''' <param name="Filename">Dateiname</param> ''' <returns>Anzahl Zeilen der Datei</returns> Public Function FileLineCount(ByVal Filename As String) As Integer Dim Lines As Integer = 0 Using oStream As New IO.FileStream(Filename, IO.FileMode.Open, IO.FileAccess.Read) ' Blockgröße Dim BlockSize As Integer = 16384 Dim Bytes(BlockSize) As Byte Dim ReadSize As Integer Dim StartIndex As Integer ' Datei blockweise auslesen, bis Dateiende erreicht Do ReadSize = oStream.Read(Bytes, 0, BlockSize) ' Anzahl Zeilenumbruchzeichen ermitteln StartIndex = -1 Do StartIndex = Array.IndexOf(Bytes, CByte(13), StartIndex + 1, ReadSize - StartIndex) If StartIndex >= 0 Then Lines += 1 Loop Until StartIndex < 0 Loop Until ReadSize = 0 oStream.Close() End Using Return Lines End Function Dieser Tipp wurde bereits 26.954 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! sevCommand 4.0 Professionelle Schaltflächen im modernen Design! Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. 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. |