C# liest effizient bestimmte Zeilen in großen Textdateien
Es müssen bestimmte Zeilen aus einer großen Textdatei gelesen werden, um die speicherintensive Lösung zu vermeiden, bei der die gesamte Datei als Array von Zeichenfolgen gespeichert wird. Die folgenden Methoden können erreicht werden:
Methode 1: Byte-Offset-Methode
FileStream.Seek
auf den berechneten Offset. StreamReader.ReadLine()
, um die Zeile zu lesen. Methode 2: LINQ-Methode (anwendbar für .NET 4.0 und höher)
File.ReadLines(fileName).Skip(line - 1).Take(1).First()
. Methode drei: Benutzerdefinierter Zeilenleser
Beispiel (Methode 1)
<code class="language-csharp">public static string GetLine(string fileName, int line) { using (var sr = new StreamReader(fileName)) { // ... (代码略,此处需补充计算字节偏移量和读取行的逻辑) ... } }</code>
Verarbeitung strukturierter Dokumente
Für strukturierte Dokumente können Sie die folgenden Strategien verwenden:
File.ReadLines(fileName).Take(25).ToArray()
, um die ersten 25 Zeilen zu lesen. X
zu bestimmen. File.ReadLines(fileName).Skip(25).Take(X).ToArray()
, um die nächsten X
Zeilen zu lesen. Mit diesen Methoden können Sie bestimmte Zeilen aus einer großen Textdatei effizient lesen, ohne die gesamte Datei in den Speicher zu laden. Welche Methode Sie wählen, hängt von der spezifischen Größe, Struktur und .NET Framework-Version der Datei ab.
Das obige ist der detaillierte Inhalt vonWie kann ich mit C# effizient auf eine bestimmte Zeile in einer großen Textdatei zugreifen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!