Установить DataFormatString для DataGridView во время выполнения?

Можно ли установить свойство DataFormatString столбца или ячейки в ASP.NET DataGridView во время выполнения?

3 ответа

Решение

Кажется, нет способа установить свойство 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);
    }
  }
}

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

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

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

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

Другие вопросы по тегам