a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

C#對DataTable里數據排序的方法

2020-01-24 03:04:49
字體:
來源:轉載
供稿:網友

直接給個實例代碼吧

復制代碼 代碼如下:

protected void Page_Load(object sender, EventArgs e)
    {
        DataTable dt = new DataTable();
        dt.Columns.Add("Name");
        dt.Columns.Add("Age");//因為是字符串,所以排序不對
        dt.Rows.Add("小明", "21");
        dt.Rows.Add("小張", "10");
        dt.Rows.Add("小紅", "9");
        dt.Rows.Add("小偉", "7");
        dt.Rows.Add("小美", "3");
        dt.DefaultView.Sort = "Age ASC";
        dt = dt.DefaultView.ToTable();

        foreach (DataRow s in dt.Rows)
        {
            Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
        }
        Response.Write("------------------1----------------<br/>");

 
        #region 方法1:將年齡補齊為2位,然后再進行排序,但是實際不應該有0(僅作參考)
        for (int i = 0; i < dt.Rows.Count; i++)
        {
            dt.Rows[i]["Age"] = dt.Rows[i]["Age"].ToString().PadLeft(2, '0');
        }
        dt.DefaultView.Sort = "Age ASC";

        dt = dt.DefaultView.ToTable();

        foreach (DataRow s in dt.Rows)
        {
            Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
        }
        #endregion

        Response.Write("------------------2----------------<br/>");

        #region 方法2:創建新的DataTable,將Age類型變更為int類型
        DataTable dtNew = dt.Clone();
        dtNew.Columns["Age"].DataType = typeof(int);//指定Age為Int類型
        foreach (DataRow s in dt.Rows)
        {
            dtNew.ImportRow(s);//導入舊數據
        }

        dtNew.DefaultView.Sort = "Age ASC";
        dtNew = dtNew.DefaultView.ToTable();

        foreach (DataRow s in dtNew.Rows)
        {
            Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
        }
        #endregion

        Response.Write("-----------------3-----------------<br/>");

        #region 方法3:添加一列,主要用于排序
        dt.Columns.Add("AgeLength", typeof(int), "len(Age)");//添加該列時,DataTable列數據即生成

        dt.DefaultView.Sort = "AgeLength,Age ASC";
        dt = dt.DefaultView.ToTable();

        foreach (DataRow s in dt.Rows)
        {
            Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
        }
        #endregion

        Response.Write("-----------------4-----------------<br/>");

        #region 方法4:運用LinQ,將DataTable轉換為集合,再調用集合自帶的排序方法進行排序
        foreach (DataRow s in dt.Rows.Cast<DataRow>().OrderBy(r => int.Parse(r["Age"].ToString())))
        {
            Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
        }
        #endregion
    }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 在线成人免费观看www | 久久88| 亚洲 欧美 综合 | 亚洲视频在线看 | 福利视频网址 | 国产一二在线 | 999免费视频 | 九一亚洲精品 | 国产精品一区二区在线看 | 色综合久 | 日韩三区 | 久久久久久国产精品 | 精品欧美一区二区在线观看视频 | 亚洲综合无码一区二区 | 99精品一区二区 | www.9色| 国产在线观看91一区二区三区 | www.久久久久 | 日韩高清二区 | 亚洲一区二区三区福利 | 日本五月婷婷 | 蜜桃久久久久久久 | 国产高清精品一区 | 欧美干b| 国产精品一区免费观看 | 日日噜噜噜噜久久久精品毛片 | 成人免费在线视频观看 | 亚洲成av人片在线观看无码 | 国产精品视频二区不卡 | 日本超碰 | 久久久久久亚洲 | 国精日本亚洲欧州国产中文久久 | 中文字幕 国产精品 | 国产精品嫩草99av在线 | 久久综合99re88久久爱 | 国产欧美在线观看 | 色综合成人 | 这里只有精品在线视频观看 | 久精品在线| 欧美一区久久 | 久久国产一区二区 |