一,在C#中要对Datatable排序,可使用DefaultView的Sort方法。先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTable方法将排好序的dataview导出为Datatable。
     代码如下:
            DataTable dt = new DataTable();
            dt.Columns.Add("ID", typeof(int));
            dt.Columns.Add("Name", typeof(string));

dt.Rows.Add(new object[] { 12, "lwolf" });
            dt.Rows.Add(new object[] { 100,"kkkkk"});
            dt.Rows.Add(new object[] { 19,"jim" });
            dt.Rows.Add(new object[] { 1,"test" });

DataTable dtCopy = dt.Copy(); //注释
            DataView dv = dt.DefaultView;
            dv.Sort = "ID";
            dtCopy = dv.ToTable();

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

二,具体排序示例

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
    }

三,

DataTable的Select()方法返回的是一个DataRow的数组,
在你的代码中 dt31 = dt30.Select("发票号= '"+a+"'");显然dt31是Datatable类型,赋值号后面是DataRow数组。
分析楼主的意思,可能是想要dt30中的发票号为 a的数据,组成一个新的Datatable作为Gridview的数据源吧?
要是的话可以用下面的代码:
string a;
a =dt30.Rows[0][1].ToString();
DataView dataView = dt30.DefaultView;//定义一个DataView为dt30的默认视图
dataView.RowFilter = "发票号 = '"+a+"'"; //对dataView进行筛选

this.dataGridView5.DataSource = dataView;//筛选后的dataView做数据源

转载于:https://www.cnblogs.com/Unrmk-LingXing/p/4048990.html

C# 对Datatable排序相关推荐

  1. DataTable排序,检索,合并,筛选

    http://apps.hi.baidu.com/share/detail/16252525 DataTable排序,检索,合并,筛选 DataTable排序,检索,合并详解 一.排序 1 获取Dat ...

  2. DataTable 排序

    DataTable排序,检索,合并 一.排序 1 获取DataTable的默认视图 2 对视图设置排序表达式 3 用排序后的视图导出的新DataTable替换就DataTable (Asc升序可省略, ...

  3. C# Datatable排序与取前几行数据

    在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTab ...

  4. java jsf table_JSF数据表(h:dataTable)排序数据

    JSF中有一个叫作DataTable的控件,可用来渲染和格式化html表格.使用DataTable,我们可以迭代收集或数组数组来显示数据.下面我们来学习如何向DataTable排序数据. 要使用Dat ...

  5. DataTable排序的一般方法

    一.重生法 dstaset.Tables.Add(dt) dataset.Tables(0).DefaultView.Sort = "id desc" 二.直接法 dv = New ...

  6. 对datatable操作经验-排序和分页

    1.datatable排序1: public DataTable SortDesc(DataTable dt){ DataView dv = new DataView(); dv.Table = dt ...

  7. 媲美Pandas?一文入门Python的Datatable操作

    作者 | Parul Pandey 译者 | linstancy 责编 | Jane 出品 | Python大本营(id:pythonnews) [导读]工具包 datatable 的功能特征与 Pa ...

  8. ArcEngine实现要素类排序的四种方法

    ArcEngine的排序方法有多种,下面介绍一下主要的四种方法. 准备数据 测试数据如下图所示:新建一个Geodatabase的要素类,其中Name为道路名称,Width为道路宽度,下面将根据Widt ...

  9. DataTable本身的查询操作

    有一个用户表userInfo 和一个DataTable保存的是userInfo里的所有用户信息 一些简单的可以在DataTable里进行的查询,可以避免多次访问数据库. 1.查询userInfo里最小 ...

最新文章

  1. 工作5年才有自己博客...汗...
  2. C#Swagger使用
  3. debian9宝塔面板安装php失败,宝塔面板安装php失败:提示No package 'libjpeg' found的解决办法...
  4. 前端app调起摄像头 只显示在页面_猫也能看得懂的教程之一分钟使用Vue搭建简单Web页面...
  5. android 下拉刷新 组件,android系统自带下拉刷新控件的实现
  6. SAP Spartacus 服务器端渲染找不到 index 视图的问题
  7. 前端快闪三:多环境灵活配置react
  8. 堆排序java实例_堆排序(示例代码)
  9. python数据处理随笔总结
  10. Spring MVC重定向和转发
  11. java pdf转为png_java-使用icepdf实现pdf转换成png
  12. 京东物流:将连续第10年春节也送货 为坚守岗位一线员工补贴近4亿元
  13. codeforce Gym 100418K Cards (概率,数学)
  14. (百看不如一练系列)整理的40个前端练手项目|||实践出真知
  15. NV21 旋转+转为NV12
  16. 添加Extension库
  17. Nachi机器人TCP通讯
  18. 论文阅读笔记《Low-shot Visual Recognition by Shrinking and Hallucinating Features》
  19. TabLayout 之改变 Indicator 的宽度
  20. HTML学习笔记4:如何给网页添加图片和超链接

热门文章

  1. BeanFactory与FactoryBean的区别
  2. mysql下一个版本号_mysql下一个版本应该且实现并不复杂增加的常用功能
  3. ef core mysql 生成迁移失败_EFCore + MySql codeFirst 迁移 Migration出现的问题
  4. java天气预报webservice_webservice之实现天气预报
  5. 计算机系统基础:计算机可靠性知识笔记
  6. Centos7搭建SVN服务步骤说明
  7. linux 连接数 限制,linux设置最大连接数
  8. linux环境下Ncurses实现贪吃蛇游戏
  9. socket 网络 编程
  10. c++ pat 乙级 ---1004 成绩排名