2012-10-17 8 views
6

Używam DataTable z treściąDataTable kolumna Reorder

 column1 column2 column3 column4 column5 column6 column7 column8 column9 column10 
row1 a   b   c   d  e  f  g  h  i  j 

chcę stół do reorderd jak

 column4 column2 column1 column7 column6 column9 column10 column5 column8 column3 
row1  d   b   a   g  f  i  j  e  h  c  

Próbowałem przy użyciu metody DataTable.Column[i].SetOrdinal() ale zamienia tylko pierwszą kolumnę prawidłowo.

+2

dlaczego chcesz zmienić kolejność w datatable? – Shyju

+0

jeśli to jest do wyświetlania tabeli gdzieś, to prawdopodobnie stwierdzisz, że większość (wszystkich) standardowych sposobów wyświetlania go pozwoli ci ustawić kolejność kolumn wyświetlanych w ... – Chris

+0

możliwy duplikat [Jak zmienić kolumny DataTable zamówienie] (http://stackoverflow.com/questions/3757997/how-to-change-datatable-colums-order) –

Odpowiedz

9

Ponieważ nie pokazałeś pełnego kodu, trudno jest powiedzieć, co faktycznie jest nie tak. Ale to powinno działać:

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

Zamiast wartości params String[] można również użyć List<DataColumn> lub whatelse wolisz.

Testowane z przykładowych danych:

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

Works już z .NET 2.

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

count nie muszą być takie same.