C #: scorrere le righe di una stringa multilinea


100

Qual è un buon modo per scorrere ogni riga di una stringa multilinea senza utilizzare molta più memoria (ad esempio senza dividerla in un array)?

Risposte:


158

Suggerisco di utilizzare una combinazione di StringReadere la mia LineReaderclasse, che fa parte di MiscUtil ma disponibile anche in questa risposta StackOverflow : puoi facilmente copiare solo quella classe nel tuo progetto di utilità. Lo useresti in questo modo:

string text = @"First line
second line
third line";

foreach (string line in new LineReader(() => new StringReader(text)))
{
    Console.WriteLine(line);
}

Loop su tutte le linee in un corpo di dati stringa (che sia un file o altro) è così comune che non dovrebbe richiedere il codice chiamante da test per nulla ecc :) Detto questo, se non vuole fare un loop manuale, questa è la forma che di solito preferisco a quella di Fredrik:

using (StringReader reader = new StringReader(input))
{
    string line;
    while ((line = reader.ReadLine()) != null)
    {
        // Do something with the line
    }
}

In questo modo devi solo testare la nullità una volta, e non devi nemmeno pensare a un ciclo do / while (che per qualche motivo mi richiede sempre più impegno di leggere rispetto a un ciclo while diretto).


74

Puoi usare a StringReaderper leggere una riga alla volta:

using (StringReader reader = new StringReader(input))
{
    string line = string.Empty;
    do
    {
        line = reader.ReadLine();
        if (line != null)
        {
            // do something with the line
        }

    } while (line != null);
}

1
Grande; +1; questo ha aiutato; ma voglio solo aggiungere che in realtà non è necessario utilizzare il blocco "using" perché in questo caso non ci sono risorse da chiudere. Vedere le osservazioni nell'articolo di StringReader su docs.microsoft.com
RD Alkire il

10

So che è stata data una risposta, ma vorrei aggiungere la mia risposta:

using (var reader = new StringReader(multiLineString))
{
    for (string line = reader.ReadLine(); line != null; line = reader.ReadLine())
    {
        // Do something with the line
    }
}

7

da MSDN per StringReader

    string textReaderText = "TextReader is the abstract base " +
        "class of StreamReader and StringReader, which read " +
        "characters from streams and strings, respectively.\n\n" +

        "Create an instance of TextReader to open a text file " +
        "for reading a specified range of characters, or to " +
        "create a reader based on an existing stream.\n\n" +

        "You can also use an instance of TextReader to read " +
        "text from a custom backing store using the same " +
        "APIs you would use for a string or a stream.\n\n";

    Console.WriteLine("Original text:\n\n{0}", textReaderText);

    // From textReaderText, create a continuous paragraph 
    // with two spaces between each sentence.
    string aLine, aParagraph = null;
    StringReader strReader = new StringReader(textReaderText);
    while(true)
    {
        aLine = strReader.ReadLine();
        if(aLine != null)
        {
            aParagraph = aParagraph + aLine + " ";
        }
        else
        {
            aParagraph = aParagraph + "\n";
            break;
        }
    }
    Console.WriteLine("Modified text:\n\n{0}", aParagraph);

2

Ecco un breve snippet di codice che troverà la prima riga non vuota in una stringa:

string line1;
while (
    ((line1 = sr.ReadLine()) != null) &&
    ((line1 = line1.Trim()).Length == 0)
)
{ /* Do nothing - just trying to find first non-empty line*/ }

if(line1 == null){ /* Error - no non-empty lines in string */ }

2

Per aggiornare questa antica domanda per .NET 4, ora c'è un modo molto più ordinato:

var lines = File.ReadAllLines(filename);

foreach (string line in lines)
{
    Console.WriteLine(line);
}

0

Prova a utilizzare il metodo String.Split:

string text = @"First line
second line
third line";

foreach (string line in text.Split('\n'))
{
    // do something
}
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.