C# 对Datatable排序
一,在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排序相关推荐
- DataTable排序,检索,合并,筛选
http://apps.hi.baidu.com/share/detail/16252525 DataTable排序,检索,合并,筛选 DataTable排序,检索,合并详解 一.排序 1 获取Dat ...
- DataTable 排序
DataTable排序,检索,合并 一.排序 1 获取DataTable的默认视图 2 对视图设置排序表达式 3 用排序后的视图导出的新DataTable替换就DataTable (Asc升序可省略, ...
- C# Datatable排序与取前几行数据
在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTab ...
- java jsf table_JSF数据表(h:dataTable)排序数据
JSF中有一个叫作DataTable的控件,可用来渲染和格式化html表格.使用DataTable,我们可以迭代收集或数组数组来显示数据.下面我们来学习如何向DataTable排序数据. 要使用Dat ...
- DataTable排序的一般方法
一.重生法 dstaset.Tables.Add(dt) dataset.Tables(0).DefaultView.Sort = "id desc" 二.直接法 dv = New ...
- 对datatable操作经验-排序和分页
1.datatable排序1: public DataTable SortDesc(DataTable dt){ DataView dv = new DataView(); dv.Table = dt ...
- 媲美Pandas?一文入门Python的Datatable操作
作者 | Parul Pandey 译者 | linstancy 责编 | Jane 出品 | Python大本营(id:pythonnews) [导读]工具包 datatable 的功能特征与 Pa ...
- ArcEngine实现要素类排序的四种方法
ArcEngine的排序方法有多种,下面介绍一下主要的四种方法. 准备数据 测试数据如下图所示:新建一个Geodatabase的要素类,其中Name为道路名称,Width为道路宽度,下面将根据Widt ...
- DataTable本身的查询操作
有一个用户表userInfo 和一个DataTable保存的是userInfo里的所有用户信息 一些简单的可以在DataTable里进行的查询,可以避免多次访问数据库. 1.查询userInfo里最小 ...
最新文章
- 工作5年才有自己博客...汗...
- C#Swagger使用
- debian9宝塔面板安装php失败,宝塔面板安装php失败:提示No package 'libjpeg' found的解决办法...
- 前端app调起摄像头 只显示在页面_猫也能看得懂的教程之一分钟使用Vue搭建简单Web页面...
- android 下拉刷新 组件,android系统自带下拉刷新控件的实现
- SAP Spartacus 服务器端渲染找不到 index 视图的问题
- 前端快闪三:多环境灵活配置react
- 堆排序java实例_堆排序(示例代码)
- python数据处理随笔总结
- Spring MVC重定向和转发
- java pdf转为png_java-使用icepdf实现pdf转换成png
- 京东物流:将连续第10年春节也送货 为坚守岗位一线员工补贴近4亿元
- codeforce Gym 100418K 	Cards (概率,数学)
- (百看不如一练系列)整理的40个前端练手项目|||实践出真知
- NV21 旋转+转为NV12
- 添加Extension库
- Nachi机器人TCP通讯
- 论文阅读笔记《Low-shot Visual Recognition by Shrinking and Hallucinating Features》
- TabLayout 之改变 Indicator 的宽度
- HTML学习笔记4:如何给网页添加图片和超链接
热门文章
- BeanFactory与FactoryBean的区别
- mysql下一个版本号_mysql下一个版本应该且实现并不复杂增加的常用功能
- ef core mysql 生成迁移失败_EFCore + MySql codeFirst 迁移 Migration出现的问题
- java天气预报webservice_webservice之实现天气预报
- 计算机系统基础:计算机可靠性知识笔记
- Centos7搭建SVN服务步骤说明
- linux 连接数 限制,linux设置最大连接数
- linux环境下Ncurses实现贪吃蛇游戏
- socket 网络 编程
- c++ pat 乙级 ---1004 成绩排名