2009-08-13 3 views

ответ

1

Там, кажется, не быть способ установить свойство DataFormatString. Я в конечном итоге связывания источника данных в таблице, а затем проходит через все клетки и их форматирования вручную:

DataGridView.AutoGenerateColumns = true; 
DataGridView.DataSource = dbconnection.getDataReader(); 
DataGridView.DataBind(); 

int result; 

for (int i = 0; i < DataGridView.Rows.Count; i++) 
{ 
    foreach (TableCell c in DataGridView.Rows[i].Cells) 
    { 
    if (int.TryParse(c.Text, out result)) 
    { 
     c.Text = String.Format("{0:n0}", result); 
    } 
    } 
} 

Этот метод отлично работает для меня. Не уверен, как это будет расширяться с помощью большого набора данных, хотя я предполагаю, что все будет хорошо.

1

Не знаю, что я знаю, возможно, вы захотите попробовать форматировать форматирование столбцов на событии RowDataBound, хотя может иметь некоторое ухудшение производительности. Будет рад, если кто-то может предоставить более простой метод.

2

Это должно сработать.

BoundField priceField = grid.Columns[0] as BoundField; 
priceField.DataFormatString = "{0:c}"; 
priceField.HtmlEncode = false; 
grid.DataSource = list; 
grid.DataBind(); 

Найденный через http://geekswithblogs.net/michelotti/archive/2006/03/30/73896.aspx

+1

Будет ли это работать для автогенерированных столбцов? Сомневаюсь, да? –