使DataTable中的第一行成为列的名称

cyb*_*ain 5 c# datatable

我试图将DataTable的第一行设置为列名.我正在使用Code Project 的GenericParsing库.问题是解析器为列设置了默认名称.

谢谢.

Ale*_* Dn 13

我认为你需要以下内容:

foreach (DataColumn column in table.Columns)
{
    string cName = table.Rows[0][column.ColumnName].ToString();
    if (!table.Columns.Contains(cName) && cName != "")
    {
         column.ColumnName = cName;
    }

}

table.Rows[0].Delete(); //If you don't need that row any more
Run Code Online (Sandbox Code Playgroud)


Sha*_*ard 8

这应该做你想要的:

DataRow firstRow = table.NewRow();
List<string> names = new List<string>();
foreach (DataColumn column in table.Columns)
{
    names.Add(column.ColumnName);
}
firstRow.ItemArray = names.ToArray();
table.Rows.InsertAt(firstRow, 0);
Run Code Online (Sandbox Code Playgroud)

如果第一行已经存在并且您想要"覆盖",则将第一行更改为:

DataRow firstRow = table.Rows[0];
Run Code Online (Sandbox Code Playgroud)

并删除最后一行.