C#对DataTable里数据排序的方法

 更新时间:2013年11月18日 11:52:08   作者:  
在日常开发过程中,有一个DataTable集合,里面有很多字段,现在要求针对某一列进行排序,如果该列为数字的话,进行ASC即可实现,但是该字段类型为string,此时排序就有点不正确了

直接给个实例代码吧

复制代码 代码如下:

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
    }

相关文章

  • C# 实现SDL2进行视频播放窗口截图和字幕添加

    C# 实现SDL2进行视频播放窗口截图和字幕添加

    这篇文章主要介绍了C# 实现SDL2进行视频播放窗口截图和字幕添加,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • C#导出Excel的示例详解

    C#导出Excel的示例详解

    这篇文章主要为大家详细介绍了C#导出Excel的示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • C#面向对象编程中里氏替换原则的示例详解

    C#面向对象编程中里氏替换原则的示例详解

    在面向对象编程中,SOLID 是五个设计原则的首字母缩写,旨在使软件设计更易于理解、灵活和可维护。本文将通过实例详细讲讲C#面向对象编程中里氏替换原则,需要的可以参考一下
    2022-07-07
  • C#实现改变DataGrid某一行和单元格颜色的方法

    C#实现改变DataGrid某一行和单元格颜色的方法

    这篇文章主要介绍了C#实现改变DataGrid某一行和单元格颜色的方法,主要涉及DataGrid控件的添加与使用、数据源的绑定、单元格与行的获取等操作。需要的朋友可以参考下
    2014-09-09
  • 在C#中新手易犯的典型缺陷

    在C#中新手易犯的典型缺陷

    这篇文章的主要内容是关于C#那些新手易犯的典型缺陷,只有对有可能犯的错误进行总结才能做得更好,需要的朋友可以参考下
    2015-07-07
  • C#结构体特性实例分析

    C#结构体特性实例分析

    这篇文章主要介绍了C#结构体特性,以实例形式较为详细的分析了C#结构体的功能、定义及相关特性,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-09-09
  • 一款域名监控小工具 Domain(IP)Watcher 实现代码

    一款域名监控小工具 Domain(IP)Watcher 实现代码

    域名是否正常,网站是否可以正常访问是很头痛的问题,怎样简单地监控域名是否可以正常访问呢,这里发布一款域名监控小工具:Domain(IP)Watcher
    2011-11-11
  • C#微信公众号开发之自定义菜单

    C#微信公众号开发之自定义菜单

    这篇文章介绍了C#微信公众号开发之自定义菜单,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • C#委托delegate实例解析

    C#委托delegate实例解析

    这篇文章主要介绍了C#委托delegate实例解析,对C#的委托做了较为深入的剖析,很适合初学者学习,需要的朋友可以参考下
    2014-08-08
  • C# lambda表达式原理定义及实例详解

    C# lambda表达式原理定义及实例详解

    这篇文章主要介绍了C# lambda表达式原理定义及实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07

最新评论