将 IEnumerable 字符串数组转换为数据表
本文关键字:数据表 转换 数组 IEnumerable 字符串 | 更新日期: 2023-09-27 18:30:16
我有一个用pipe(|)分隔的csv文件。我正在使用以下代码行阅读它:
IEnumerable<string[]> lineFields = File.ReadAllLines(FilePath).Select(line => line.Split('|'));
现在,我需要将其绑定到GridView
。所以我正在创建一个动态DataTable
,如下所示:
DataTable dt = new DataTable();
int i = 0;
foreach (string[] order in lineFields)
{
if (i == 0)
{
foreach (string column in order)
{
DataColumn _Column = new DataColumn();
_Column.ColumnName = column;
dt.Columns.Add(_Column);
i++;
//Response.Write(column);
//Response.Write("'t");
}
}
else
{
int j = 0;
DataRow row = dt.NewRow();
foreach (string value in order)
{
row[j] = value;
j++;
//Response.Write(column);
//Response.Write("'t");
}
dt.Rows.Add(row);
}
//Response.Write("'n");
}
这工作正常。但是我想知道是否有更好的方法可以将IEnumerable<string[]>
转换为DataTable
。我需要阅读许多这样的 CSV,所以我认为上面的代码可能存在性能问题。
从 .Net 4 开始:
使用 ReadLines
.
DataTable FileToDataTable(string FilePath)
{
var dt = new DataTable();
IEnumerable<string[]> lineFields = File.ReadLines(FilePath).Select(line => line.Split('|'));
dt.Columns.AddRange(lineFields.First().Select(i => new DataColumn(i)).ToArray());
foreach (var order in lineFields.Skip(1))
dt.Rows.Add(order);
return dt;
}
(编辑:代替此代码,请使用@Jodrell答案的代码,这可以防止枚举器的双重收费)。
在 .Net 4 之前:
使用流式处理:
DataTable FileToDataTable1(string FilePath)
{
var dt = new DataTable();
using (var st = new StreamReader(FilePath))
{
// first line procces
if (st.Peek() >= 0)
{
var order = st.ReadLine().Split('|');
dt.Columns.AddRange(order.Select(i => new DataColumn(i)).ToArray());
}
while (st.Peek() >= 0)
dt.Rows.Add(st.ReadLine().Split('|'));
}
return dt;
}
因为在链接的示例中,该文件具有标题行。
const char Delimiter = '|';
var dt = new DataTable;
using (var m = File.ReadLines(filePath).GetEnumerator())
{
m.MoveNext();
foreach (var name in m.Current.Split(Delimiter))
{
dt.Columns.Add(name);
}
while (m.MoveNext())
{
dt.Rows.Add(m.Current.Split(Delimiter));
}
}
这将一次性读取文件。