我正在使用内容<{p>的DataTable
column1 column2 column3 column4 column5 column6 column7 column8 column9 column10
row1 a b c d e f g h i j
我希望将表重新排序为
column4 column2 column1 column7 column6 column9 column10 column5 column8 column3
row1 d b a g f i j e h c
我尝试使用DataTable.Column[i].SetOrdinal()
方法,但它只是正确地交换了第一列。
答案 0 :(得分:9)
由于您没有显示完整的代码,因此很难说出实际上是错的。但这应该有效:
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<DataColumn>
。
使用您的示例数据进行测试:
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。
答案 1 :(得分:0)
int cnt = 0;
foreach (string s in colsList)
{
if (table.Columns.Contains(s))
{
table.Columns[s].SetOrdinal(cnt);
cnt++;
}
}
算不需要相同。