DataTable列重新排序

我正在使用带有内容的DataTable

  column1 column2 column3 column4 column5 column6 column7 column8 column9 column10 row1 abcdefghij 

我希望将表重新排序为

  column4 column2 column1 column7 column6 column9 column10 column5 column8 column3 row1 dbagfijehc 

我尝试使用DataTable.Column[i].SetOrdinal()方法,但它只是正确地交换了第一列。

由于您没有显示完整的代码,因此很难说出实际上是错误的。 但这应该工作:

 public static void ReorderTable(ref DataTable table, params String[] columns) { if (columns.Length != table.Columns.Count) throw new ArgumentException("Count of columns must be equal to table.Column.Count", "columns"); for (int i = 0; i < columns.Length; i++) { table.Columns[columns[i]].SetOrdinal(i); } } 

而不是params String[]你也可以使用List或whatelse。

使用您的示例数据进行测试:

 var table = new DataTable(); table.Columns.Add("column1", typeof(string)); table.Columns.Add("column2", typeof(string)); table.Columns.Add("column3", typeof(string)); table.Columns.Add("column4", typeof(string)); table.Columns.Add("column5", typeof(string)); table.Columns.Add("column6", typeof(string)); table.Columns.Add("column7", typeof(string)); table.Columns.Add("column8", typeof(string)); table.Columns.Add("column9", typeof(string)); table.Columns.Add("column10", typeof(string)); for (int i = 0; i < 10; i++) { table.Rows.Add("colum1", "column2", "colum3", "column4", "column5", "column6", "column7", "column8", "column9", "column10"); } ReorderTable(ref table, "column4", "column2", "column1", "column7", "column6", "column9", "column10", "column5", "column8", "column3"); 

已经与.NET 2一起使用。

 int cnt = 0; foreach (string s in colsList) { if (table.Columns.Contains(s)) { table.Columns[s].SetOrdinal(cnt); cnt++; } } 

数量不必相同。