[C#] C# DataTable实现行列转换的代码 →→→→→进入此内容的聊天室

来自 , 2019-09-07, 写在 C#, 查看 130 次.
URL http://www.code666.cn/view/952575f5
  1.     protected void Page_Load(object sender, EventArgs e)
  2.     {
  3.         if (!IsPostBack)
  4.         {
  5.             DataTable tt = GetCrossTable(CreateDT());
  6.             GridView1.DataSource = tt;
  7.             GridView1.DataBind();
  8.         }
  9.     }
  10.  
  11.     //创建DataTable
  12.     protected DataTable CreateDT()
  13.     {
  14.         DataTable tblDatas = new DataTable("Datas");
  15.         //数据列
  16.         tblDatas.Columns.Add("姓名", Type.GetType("System.String"));
  17.         tblDatas.Columns.Add("科目", Type.GetType("System.String"));
  18.         tblDatas.Columns.Add("分数", Type.GetType("System.Int32"));
  19.  
  20.         tblDatas.Rows.Add(new object[] { "张三", "语文", 89 });
  21.         tblDatas.Rows.Add(new object[] { "张三", "数学", 90 });
  22.         tblDatas.Rows.Add(new object[] { "张三", "英语", 79 });
  23.         tblDatas.Rows.Add(new object[] { "张三", "地理", 70 });
  24.         tblDatas.Rows.Add(new object[] { "张三", "生物", 95 });
  25.  
  26.         tblDatas.Rows.Add(new object[] { "李四", "语文", 87 });
  27.         tblDatas.Rows.Add(new object[] { "李四", "英语", 86 });
  28.         tblDatas.Rows.Add(new object[] { "李四", "地理", 82 });
  29.  
  30.         tblDatas.Rows.Add(new object[] { "王五", "语文", 81 });
  31.         tblDatas.Rows.Add(new object[] { "王五", "数学", 70 });
  32.         tblDatas.Rows.Add(new object[] { "王五", "英语", 88 });
  33.         tblDatas.Rows.Add(new object[] { "王五", "生物", 96 });
  34.         return tblDatas;
  35.     }
  36.  
  37.     /// <summary>
  38.     /// 将DataTable的第二列的值转化为列(即将原来的行表,转化成交叉表,没有对应值则默认"0")
  39.     /// </summary>
  40.     /// <param name="dt">必须三列,第三列为值</param>
  41.     /// <returns></returns>
  42.     public static DataTable GetCrossTable(DataTable dt)
  43.     {
  44.         if (dt == null || dt.Columns.Count != 3 || dt.Rows.Count == 0)
  45.         {
  46.             return dt;
  47.         }
  48.         else
  49.         {
  50.             DataTable result = new DataTable();
  51.             result.Columns.Add(dt.Columns[0].ColumnName);
  52.             DataTable dtColumns = dt.DefaultView.ToTable("dtColumns", true, dt.Columns[1].ColumnName);
  53.             for (int i = 0; i < dtColumns.Rows.Count; i++)
  54.             {
  55.                 string colName;
  56.                 if (dtColumns.Rows[1][0] is DateTime)
  57.                 {
  58.                     colName = Convert.ToDateTime(dtColumns.Rows[i][0]).ToString();
  59.                 }
  60.                 else
  61.                 {
  62.                     colName = dtColumns.Rows[i][0].ToString();
  63.                 }
  64.                 result.Columns.Add(colName);
  65.                 result.Columns[i + 1].DefaultValue = "0";
  66.             }
  67.             DataRow drNew = result.NewRow();
  68.             drNew[0] = dt.Rows[0][0];
  69.             string rowName = drNew[0].ToString();
  70.             foreach (DataRow dr in dt.Rows)
  71.             {
  72.                 string colName = dr[1].ToString();
  73.                 double dValue = Convert.ToDouble(dr[2]);
  74.                 if (dr[0].ToString().Equals(rowName, StringComparison.CurrentCultureIgnoreCase))
  75.                 {
  76.                     drNew[colName] = dValue.ToString();
  77.                 }
  78.                 else
  79.                 {
  80.                     result.Rows.Add(drNew);
  81.                     drNew = result.NewRow();
  82.                     drNew[0] = dr[0];
  83.                     rowName = drNew[0].ToString();
  84.                     drNew[colName] = dValue.ToString();
  85.                 }
  86.             }
  87.             result.Rows.Add(drNew);
  88.             return result;
  89.         }
  90.     }
  91. //csharp/6395

回复 "C# DataTable实现行列转换的代码"

这儿你可以回复上面这条便签

captcha