2

我正在尝试通过 FileHelpers 动态读取 CSV 并将 CSV 数据作为数据表处理。我的 CSV 文件将不一样。它们将具有不同的列标题和不同数量的列。我正在使用 ReadStreamAsDT 方法,但似乎仍然需要一个结构化类来初始化 FileHelperEngine。有任何想法吗?

4

2 回答 2

4

我不得不使用FileHelpers.RunTimeand来从文件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 回答