File.ReadAllLines 或 Stream Reader

File.ReadAllLines or Stream Reader(File.ReadAllLines 或 Stream Reader)
本文介绍了File.ReadAllLines 或 Stream Reader的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我们可以使用 StreamReader 或使用 File.ReadAllLines.

We can read file either by using StreamReader or by using File.ReadAllLines.

例如,我想将每一行加载到 Liststring[] 中,以便对每一行进行进一步操作.

For example I want to load each line into a List or string[] for further manipulation on each line.

string[] lines = File.ReadAllLines(@"C:\file.txt");

foreach(string line in lines)
{
     //DoSomething(line);
}

using (StreamReader reader = new StreamReader("file.txt"))
{
    string line;

    while ((line = reader.ReadLine()) != null)
    {
       //DoSomething(line); or //save line into List<string>
    }
}

//if list is created loop through list here 

应用程序遇到不同大小的文本文件.偶尔会从几个 KBs 增长到 MBs.

Application come across different size of text file. Which could grow from few KBs to MBs occasionally.

我的问题是哪一种是首选方式,为什么应该优先选择其他方式?

My question is that which one is preferred way and why one should be preferred over other?

推荐答案

如果你想处理一个文本文件的每一行而不将整个文件加载到内存中,最好的方法是这样的:

If you want to process each line of a text file without loading the entire file into memory, the best approach is like this:

foreach (var line in File.ReadLines("Filename"))
{
    // ...process line.
}

这避免了加载整个文件,并使用现有的 .Net 函数来完成.

This avoids loading the entire file, and uses an existing .Net function to do so.

但是,如果由于某种原因需要将所有字符串存储在一个数组中,最好只使用 File.ReadAllLines() - 但如果您只使用 foreach 访问数组中的数据,然后使用File.ReadLines().

However, if for some reason you need to store all the strings in an array, you're best off just using File.ReadAllLines() - but if you are only using foreach to access the data in the array, then use File.ReadLines().

这篇关于File.ReadAllLines 或 Stream Reader的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

How to know if a field is numeric in Linq To SQL(如何在 Linq To SQL 中知道字段是否为数字)
Extract sql query from LINQ expressions(从 LINQ 表达式中提取 sql 查询)
LINQ Where in collection clause(LINQ Where in collection 子句)
Orderby() not ordering numbers correctly c#(Orderby() 没有正确排序数字 c#)
Why do I get quot;error: ... must be a reference typequot; in my C# generic method?(为什么我会收到“错误:...必须是引用类型?在我的 C# 泛型方法中?)
Strange LINQ Exception (Index out of bounds)(奇怪的 LINQ 异常(索引越界))