今天又发现了一个很有用的东西,DataGridView的CellFormating事件
经常从数据库查到的原始数据需要经过转换之后显示在客户端,比如性别,“1”显示“男”,“0”显示“女”,为此经常将数据绑定到一个下拉框中才能显示,这样出现了非法数据,比如“2”的时候,就会抛出异常,为此,用CellFormating事件就可以利用事件在数据需要显示的时候才将它转换,而且这样就有机会可以处理异常数据,例如要显示如下DataTable的数据:
private void Form1_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("Id")); dt.Columns.Add(new DataColumn("Name")); dt.Columns.Add(new DataColumn("Bit")); dt.Rows.Add(new object[] { "1", "abcd", "0"}); dt.Rows.Add(new object[] { "2", "abcd", "1" }); dt.Rows.Add(new object[] { "3", "abcd", "0" }); dt.Rows.Add(new object[] { "4", "abcd", "1" }); dt.Rows.Add(new object[] { "5", "abcd", "1" }); dt.Rows.Add(new object[] { "6", "abcd", "0" }); dataGridView1.AutoGenerateColumns = false; dataGridView1.DataSource = dt; }
这时想要让Bit显示为“是“和”否”,只需要为DataGridView1订阅事件CellFormating就可以处理数据了:
private void dataGridView1_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e) { if (Column_bit.Index == e.ColumnIndex) { if (e.Value == null) { return; } if (e.Value.Equals("0")) { e.Value = "否"; } else { e.Value = "是"; } } }
原链接:http://blog.csdn.net/testcs_dn/article/details/37834063