我有一个用管道(|)分隔的 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,所以我认为上面的代码可能存在性能问题。