国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#中DataTable實現行列轉換的方法

2020-01-24 01:54:24
字體:
來源:轉載
供稿:網友

本文實例講述了C#中DataTable實現行列轉換的方法。分享給大家供大家參考。具體實現方法如下:

protected void Page_Load(object sender, EventArgs e){  if (!IsPostBack)  {   DataTable tt = GetCrossTable(CreateDT());   GridView1.DataSource = tt;   GridView1.DataBind();  }}//創建DataTableprotected 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;  }}

希望本文所述對大家的C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 五指山市| 嘉义县| 阿鲁科尔沁旗| 蓬溪县| 郑州市| 特克斯县| 凤冈县| 天津市| 惠水县| 三台县| 西盟| 和龙市| 临夏县| 财经| 芒康县| 孝感市| 林口县| 彭泽县| 莱西市| 宁海县| 西乌珠穆沁旗| 阳朔县| 乌拉特后旗| 高雄市| 汝城县| 固始县| 崇州市| 长春市| 府谷县| 农安县| 藁城市| 凌云县| 海晏县| 湖南省| 溧水县| 错那县| 木兰县| 镇雄县| 江油市| 济阳县| 裕民县|