C#對(duì)DataTable里數(shù)據(jù)排序的方法
直接給個(gè)實(shí)例代碼吧
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = new DataTable();
dt.Columns.Add("Name");
dt.Columns.Add("Age");//因?yàn)槭亲址?,所以排序不?duì)
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:將年齡補(bǔ)齊為2位,然后再進(jìn)行排序,但是實(shí)際不應(yīng)該有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:創(chuàng)建新的DataTable,將Age類型變更為int類型
DataTable dtNew = dt.Clone();
dtNew.Columns["Age"].DataType = typeof(int);//指定Age為Int類型
foreach (DataRow s in dt.Rows)
{
dtNew.ImportRow(s);//導(dǎo)入舊數(shù)據(jù)
}
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)");//添加該列時(shí),DataTable列數(shù)據(jù)即生成
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:運(yùn)用LinQ,將DataTable轉(zhuǎn)換為集合,再調(diào)用集合自帶的排序方法進(jìn)行排序
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
}
相關(guān)文章
C# winform分頁(yè)查詢的實(shí)現(xiàn)示例
這篇文章主要介紹了C# winform分頁(yè)查詢的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04C#數(shù)據(jù)結(jié)構(gòu)之堆棧(Stack)實(shí)例詳解
這篇文章主要介紹了C#數(shù)據(jù)結(jié)構(gòu)之堆棧(Stack),結(jié)合實(shí)例形式較為詳細(xì)的分析了堆棧的原理與C#實(shí)現(xiàn)堆棧功能的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11windows系統(tǒng)下,如何在C#程序中自動(dòng)安裝字體
在Windows系統(tǒng)中,原有自帶的字體樣式有限,有時(shí)候我們的程序會(huì)使用到個(gè)別稀有或系統(tǒng)不自帶的字體。因此我們需要將字體打包到程序中,當(dāng)程序啟動(dòng)時(shí),檢測(cè)系統(tǒng)是否有該字體,如果沒(méi)有則安裝該字體,也可以動(dòng)態(tài)加載字體。2020-11-11SMTP客戶端未通過(guò)身份驗(yàn)證等多種錯(cuò)誤解決方案分享
這篇文章主要介紹了SMTP服務(wù)器要求安全連接或客戶端未通過(guò)身份驗(yàn)證的多種解決方案,感興趣的小伙伴們可以參考一下2016-05-05C#使用NPOI實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出功能
這篇文章主要為大家詳細(xì)介紹了C#使用NPOI實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02C#關(guān)聯(lián)自定義文件類型到應(yīng)用程序并實(shí)現(xiàn)自動(dòng)導(dǎo)入功能
今天通過(guò)本文給大家分享C#關(guān)聯(lián)自定義文件類型到應(yīng)用程序并實(shí)現(xiàn)自動(dòng)導(dǎo)入功能,代碼中寫(xiě)入了兩個(gè)注冊(cè)表,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09WPF利用ScottPlot實(shí)現(xiàn)動(dòng)態(tài)繪制圖像
ScottPlot是基于.Net的一款開(kāi)源免費(fèi)的交互式可視化庫(kù),支持Winform和WPF等UI框架,本文主要為大家詳細(xì)介紹了如何WPF如何使用ScottPlot實(shí)現(xiàn)動(dòng)態(tài)繪制圖像,需要的可以參考下2023-12-12關(guān)于C#.net winform程序驗(yàn)證moss的集成身份認(rèn)證實(shí)例
因?yàn)榫W(wǎng)站使用的是windows集成認(rèn)證,所以遇到了權(quán)限問(wèn)題,需要輸入密碼。使操作和用戶體驗(yàn)非常不方便,研究了好久沒(méi)有找到好的方法,最后終于讓我踏破鐵鞋總結(jié)出了下面的方法2013-03-03C#中調(diào)用SAPI實(shí)現(xiàn)語(yǔ)音合成的2種方法
這篇文章主要介紹了C#中調(diào)用SAPI實(shí)現(xiàn)語(yǔ)音合成的2種方法,本文直接給出示例代碼,需要的朋友可以參考下2015-06-06