DataTable 行列转换 将原来的行表转化成交叉表,无对应值赋默认值,用于统计显示或报表
2012-11-22 09:51
411 查看
protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { DataTable tt = GetCrossTable(CreateDT()); GridView1.DataSource = tt; GridView1.DataBind(); } } //创建DataTable protected DataTable CreateDT() { DataTable tblDatas = new DataTable("Datas"); //数据列 tblDatas.Columns.Add("姓名", Type.GetType("System.String")); tblDatas.Columns.Add("科目", Type.GetType("System.String")); tblDatas.Columns.Add("分数", Type.GetType("System.Int32")); tblDatas.Rows.Add(new object[] { "张三", "语文", 89 }); tblDatas.Rows.Add(new object[] { "张三", "数学", 90 }); tblDatas.Rows.Add(new object[] { "张三", "英语", 79 }); tblDatas.Rows.Add(new object[] { "张三", "地理", 70 }); tblDatas.Rows.Add(new object[] { "张三", "生物", 95 }); tblDatas.Rows.Add(new object[] { "李四", "语文", 87 }); tblDatas.Rows.Add(new object[] { "李四", "英语", 86 }); tblDatas.Rows.Add(new object[] { "李四", "地理", 82 }); tblDatas.Rows.Add(new object[] { "王五", "语文", 81 }); tblDatas.Rows.Add(new object[] { "王五", "数学", 70 }); tblDatas.Rows.Add(new object[] { "王五", "英语", 88 }); tblDatas.Rows.Add(new object[] { "王五", "生物", 96 }); return tblDatas; } /// <summary> /// 将DataTable的第二列的值转化为列(即将原来的行表,转化成交叉表,没有对应值则默认"0") /// </summary> /// <param name="dt">必须三列,第三列为值</param> /// <returns></returns> public static DataTable GetCrossTable(DataTable dt) { if (dt == null || dt.Columns.Count != 3 || dt.Rows.Count == 0) { return dt; } else { DataTable result = new DataTable(); result.Columns.Add(dt.Columns[0].ColumnName); DataTable dtColumns = dt.DefaultView.ToTable("dtColumns", true, dt.Columns[1].ColumnName); for (int i = 0; i < dtColumns.Rows.Count; i++) { string colName; if (dtColumns.Rows[1][0] is DateTime) { colName = Convert.ToDateTime(dtColumns.Rows[i][0]).ToString(); } else { colName = dtColumns.Rows[i][0].ToString(); } result.Columns.Add(colName); result.Columns[i + 1].DefaultValue = "0"; } DataRow drNew = result.NewRow(); drNew[0] = dt.Rows[0][0]; string rowName = drNew[0].ToString(); foreach (DataRow dr in dt.Rows) { string colName = dr[1].ToString(); double dValue = Convert.ToDouble(dr[2]); if (dr[0].ToString().Equals(rowName, StringComparison.CurrentCultureIgnoreCase)) { drNew[colName] = dValue.ToString(); } else { result.Rows.Add(drNew); drNew = result.NewRow(); drNew[0] = dr[0]; rowName = drNew[0].ToString(); drNew[colName] = dValue.ToString(); } } result.Rows.Add(drNew); return result; } }
相关文章推荐
- DataTable 行列转换 将原来的行表转化成交叉表,无对应值赋默认值,用于统计显示或报表
- SQL 二维交叉报表 分类统计(行列转换)
- 行列转换,交叉表 (统计用, 表的值转换成字段)
- sql 行列转化/交叉报表的实现
- 报一个比较难以描述的问题【关键字 报表 数据库行列转换 多表交叉查询】
- sql行列统计后,行列转换显示
- tsql 数据行列转换,交叉报表示例
- 行列转换并且进行行列数据统计 rollup
- 实现动态统计报表,表头是调用数据库中的字段显示出来的。
- SQL报表横向显示,交叉报表显示
- 交叉表、行列转换和交叉查询经典
- Netstat用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况
- 【转】Linq实现DataTable行列转换
- C#中DataTable实现行列转换的方法
- 多列转换为行的交叉报表处理示例.sql
- 将实体转化成json并将json转换成DataTable
- 个位数统计 用string str 来记录数字字符串,-'0'来转化 // str[i] -‘0’来转化成int形式 因为 str[i] -‘0’ ==》 对应数字 0--9 //只有
- 在Sqlserver下巧用行列转换日期的数据统计
- SQL报表横向显示,交叉报表显示 (1)
- 用Birt(商业智能报表)制作交叉报表(显示学生成绩)