本文来源:
qq_41441897:WPF DataGrid 列名包含敏感字符的解决方法
当使用DataGrid进行数据绑定的时候,如果后台绑定的DataTable的列名中含有特殊标点,
例如 . \ \ / [ ] ( ) 等
则会导致该列所有数据都无法显示,但确实是有值,可以通过排序发现单元格中值存在
PS:数据库安排就不该搞这些特殊符号,但没办法,碍于项目需要显示这些东西。。。
解决方案:
给要显示的DataTable添加AutoGeneratingColumn
事件
private void DataGrid_AutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
string columnName = e.PropertyName;
if (e.Column is DataGridBoundColumn &&
(columnName.Contains(".") ||
columnName.Contains("\\") ||
columnName.Contains("/") ||
columnName.Contains("[") ||
columnName.Contains("]") ||
columnName.Contains("(") ||
columnName.Contains(")")))
{
DataGridBoundColumn dataGridBoundColumn = e.Column as DataGridBoundColumn;
dataGridBoundColumn.Binding = new Binding("[" + e.PropertyName + "]");
}
}