我正在尝试通过 FileHelpers 动态读取 CSV 并将 CSV 数据作为数据表处理。我的 CSV 文件将不一样。它们将具有不同的列标题和不同数量的列。我正在使用 ReadStreamAsDT 方法,但似乎仍然需要一个结构化类来初始化 FileHelperEngine。有任何想法吗?
问问题
3961 次
2 回答
4
我不得不使用FileHelpers.RunTime
and来从文件DelimitedClassBuilder
中创建一个。DataTable
这是我的方法。如果我有更多时间,我会更好地解释这一点。
private static DataTable CreateDataTableFromFile(byte[] importFile) {
var cb = new DelimitedClassBuilder("temp", ",") { IgnoreFirstLines = 0, IgnoreEmptyLines = true, Delimiter = "," };
var ms = new MemoryStream(importFile);
var sr = new StreamReader(ms);
var headerArray = sr.ReadLine().Split(',');
foreach (var header in headerArray) {
cb.AddField(header, typeof(string));
cb.LastField.FieldQuoted = true;
cb.LastField.QuoteChar = '"';
}
var engine = new FileHelperEngine(cb.CreateRecordClass());
return engine.ReadStreamAsDT(sr);
}
显然,围绕此方法进行了大量验证以及其他逻辑,但我现在没有太多时间深入研究它。希望这可以帮助!
于 2011-05-18T13:58:33.940 回答
1
您是否尝试过使用http://www.codeproject.com/KB/database/CsvReader.aspx?你可以利用这个库的解析。它快速可靠。
于 2011-11-17T19:27:45.023 回答