我的文件大于10G。 为了逐行读取这个文件,我编写了这个函数。
static IEnumerable<string> fread(string fname, Encoding enc)
using (var f = File.OpenRead(fname))
using (var reader = new StreamReader(f, enc))
while (!reader.EndOfStream)
yield return reader.ReadLine();
}
这段代码工作得很好,但它返回一个行字符串,而不是行字节[]。 因此,为了返回每行的byte [],我写了另一个函数。
static IEnumerable<byte[]> freadbytes(string fname) {
using (var f = File.OpenRead(fname)) {
var bufSz = 1024;
var buf = new byte[bufSz];
var read = 1;
var cr = (byte)13; // \r
var lf = (byte)10; // \n
var data = new List<byte>();
while (read > 0) {
read = f.Read(buf, 0, bufSz);
data.AddRange(read == bufSz ? buf : buf.slc(0, read));
var i = data.IndexOf(lf);
while (i >= 0) {
if (i > 0 && data[i - 1] == cr) yield return data.Take(i - 1).ToArray();
else yield return data.Take(i).ToArray();
data.RemoveRange(0, i + 1);
i = data.IndexOf(lf);
}
}
}
}
第二个函数freadbytes()也运行良好,但问题是第二个函数占第一个函数的10倍以上。 为了使第二个功能更快,我该怎么办?
答案 0 :(得分:5)
虽然未经测试,但我相信这会快得多:
static IEnumerable<byte[]> fread(string fname, Encoding enc)
{
using (var f = File.OpenRead(fname))
using (var reader = new StreamReader(f, enc))
while (!reader.EndOfStream)
yield return enc.GetBytes(reader.ReadLine());
}
答案 1 :(得分:0)
也许这会有所帮助:
static IEnumerable<string> fread(string fname, Encoding enc)
using (var f = File.OpenRead(fname))
using (var reader = new StreamReader(f, enc))
while (!reader.EndOfStream)
yield return enc.GetBytes(reader.ReadLine());
}
更新:最初错过了enc
param。