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 27.029 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. |
sevZIP40 Pro DLL Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. 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. |