DataTable字符串类型的数字,按照数字类型排序
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
}
出处:http://qixuejia.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架