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 队列转换 将原来的行表转化成交叉表,无对应值赋默认值,用于统计显示或报表
热度:157 发布时间:2016-05-05 07:49:52.0
相关解决方案
- vs2010 datatable visualizer 不能用,该怎么处理
- vs2010 datatable visualizer 不能用,该如何解决
- ReportViewer 如何绑定一个动态的 DataTable
- DataTable 取值解决方法
- 100分求解决:datagridview打开Excel报错:名叫“ClampVal”的列已属于此 DataTable
- 没法将类型“bool”隐式转换为“System.Data.DataTable
- 为什么 DataTable 不能在页面中共享解决思路
- DataTable dt = GetDataSource()
- DataTable 更新数据库(只剩下30分了,请那位老大帮忙,多谢)
- DataTable 排序后绑定有关问题
- 怎么解决?DataTable 内部索引已损坏.
- DataTable 对象表中的记录怎么批量条件删除?
- DataTable 怎么转换为 XML
- 怎么使用把 XML 文件读入 DataTable 啊并且 DataTable 不能乱了
- DataTable 连接的有关问题
- 在SQLDATAREADER 、DATASET 、DATATABLE 等类中通常都回有Get.和GetSql.解决方案
- 没法将类型“object”隐式转换为“System.Data.DataTable”。存在一个显式转换(是否缺少强制转换?)
- datatable.select()中不支持单字符的通配符吗解决思路
- webservice 回来datatable无法序列化 DataTable。未设置 DataTable 名称
- webservice 回到datatable无法序列化 DataTable。未设置 DataTable 名称
- YUI 的 datatable 的使用方面的一些有关问题的总结
- jquery datatable.js插件 从服务器取数据 数据没法显示
- 高分请问,怎么使用 datatable,路过有分,(datatable jquery struts2)
- 使用jquery datatable,如何在表格前加checkbox有全选之类的功能呢
- JSF的<h:dataTable var="item"有关问题 ...
- jsf datatable 可以绑定一个HashMap么?该怎么处理
- DataTable.Compute 性能慢的有关问题
- c# sql datatable,该如何处理
- 怎么代码建立datagridview、datatable,并在datagridview中预制下拉组合框列的备选内容
- datatable 相减解决办法