8

我正在使用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()方法,但它仅正确交换第一列。

4

2 回答 2

12

由于您没有显示完整的代码,因此很难说出实际出了什么问题。但这应该有效:

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);
    }
}

除了 aparams String[]你也可以使用List<DataColumn>你喜欢的 a 或 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 一起使用。

于 2012-10-17T15:23:10.493 回答
1
int cnt = 0;
foreach (string s in colsList)
{
    if (table.Columns.Contains(s))
    {
        table.Columns[s].SetOrdinal(cnt);
        cnt++;
    }
}

计数不必相同。

于 2017-11-21T10:06:00.597 回答