C# 在运行时在DataGridView上设置DataFormatString?

C# 在运行时在DataGridView上设置DataFormatString?,c#,asp.net,datagridview,dataformat,C#,Asp.net,Datagridview,Dataformat,是否可以在运行时在ASP.NET DataGridView中设置列或单元格的DataFormatString属性?据我所知,您可能希望尝试在RowDataBound事件上设置列格式,尽管可能会降低性能。 如果有人能提供一种更简单的方法,我会很高兴的。这应该行得通 BoundField priceField = grid.Columns[0] as BoundField; priceField.DataFormatString = "{0:c}"; priceField.HtmlEncode =

是否可以在运行时在ASP.NET DataGridView中设置列或单元格的DataFormatString属性?

据我所知,您可能希望尝试在RowDataBound事件上设置列格式,尽管可能会降低性能。 如果有人能提供一种更简单的方法,我会很高兴的。

这应该行得通

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

通过

找到似乎没有设置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);
    }
  }
}
DataGridView.AutoGenerateColumns=true;
DataGridView.DataSource=dbconnection.getDataReader();
DataGridView.DataBind();
int结果;
对于(int i=0;i
这个方法对我非常有效。我不确定它将如何扩展到一个大的数据集,尽管我猜它会很好