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
}
DataTable字符串类型的数字,按照数字类型排序的更多相关文章
- double类型字符串转换成一个纯数字字符串和一个小数点位数的c++代码
今天工作中遇到一个要不一个double型的字符串转换成一个纯字数字符串和一个标志这个数字字符串的小数点有几位的int类型 例如:“23.123”--->“23123” + 3 比较简单.就是 ...
- js将某个值转换为String字符串类型或转换为Number数字类型
将某个值转换为String类型 1. value.toString() toString()方法返回一个表示该对象的字符串 var a = 123 a.toString() // '123' 2. & ...
- day05数据类型,数字类型,字符串类型,字符串的操作方法,列表类型的操作方法,可变类型与不可变类型
复习 ''' 流程控制 1.顺序结构.分支结构.循环结构 2.if分支结构 if 条件: 代码块 elif 条件: 代码块 else: 代码块 # 可以被if转换为False:0 | '' | Non ...
- JavaScript 中的数字和日期类型
本章节介绍如何掌握Javascript里的数字和日期类型 数字EDIT 在 JavaScript 里面,数字都是双精度浮点类型的 double-precision 64-bit binary form ...
- python基础——数字&集合&布尔类型
Python的核心数据类型 内置对象 对象类型 例子 数字 123,3.1415,3+4j,Decimal(小数),Fraction(分数) 字符串 'dodo',"guido's" ...
- Java中long类型直接赋值大数字 注意事项
在java中,我们都知道有八种基本数据类型:byte. char. short .int. long. float. double .boolean 下面列出以下四种数据类型及其取值范围: 本文主要讲 ...
- SQL算术数字的默认类型
select 100*100*100*100*100 --错误:将 expression 转换为数据类型 int 时出现算术溢出错误. select cast(1000 as bigint) * ...
- DB2中字符、数字和日期类型之间的转换
DB2中字符.数字和日期类型之间的转换 一般我们在使用DB2或Oracle的过程中,经常会在数字<->字符<->日期三种类 型之间做转换,那么在DB2和Oracle中,他们分别 ...
- js字符串转换成数字与数字转换成字符串的实现方法
转载:点击查看地址 js字符串转换成数字 将字符串转换成数字,得用到parseInt函数.parseInt(string) : 函数从string的开始解析,返回一个整数. 举例:parseInt(' ...
- js字符串转换成数字,数字转换成字符串
转自网络,忘记出处了. js字符串转换成数字 将字符串转换成数字,得用到parseInt函数. parseInt(string) : 函数从string的开始解析,返回一个整数. 举例:parseIn ...
随机推荐
- 数32位 unsigned int中1的个数
参考文章:http://www.cnblogs.com/graphics/archive/2010/06/21/1752421.html 最简单的方法: int BitCount0(unsigned ...
- apache支持中文域名绑定,apache支持中文域名绑定,教你怎样让apache支持中文域名绑定
摘要:apache支持中文域名绑定,apache支持中文域名绑定,教你怎样让apache支持中文域名绑定,根据本人实际经验,叫你如何让apache支持中文域名绑定,绝对管用的让apache支持中文域名 ...
- ecshop后台增加栏目查询会员是否重复注册
ecshop的后台要查询哪些会员是否有重复注册时,可以利用特定的栏目来判断~ 譬如会员电话... 修改前请务必先备份下列档案!!! admin/users.php admin/templates/us ...
- java用freemarker导出数据到word(含多图片)
一.制作word模版 新建word文档,按照需要设置好字体等各种格式:这里为了显得整齐使用了无边框的表格. 将word文档另存为xml文件(注意不是word xml文档,我吃了这家伙的大亏了) 然后用 ...
- 测试post
http://www.atool.org/httptest.php 这里也可以测试 火狐有插件:HttpRequester Chrome有插件:Postman
- Spring资源访问
资源访问 1.Resource Jdk提供的访问资源的类并不能很好地满足各种底层的资源访问需求, 比如缺少从类路径或者web容器的上下文中获取资源的操作类. 鉴于此, Spring设计了一个Resou ...
- 使用Keil的MicroLIB时自动设置堆大小——玩嵌入式以来最高难度
Keil编译项目,如果使用微库MicroLIB,就可以使用malloc.微库内部位置一个堆管理模块.芯片的RAM大小是固定了的,前面分为全局变量,后面分给堆和栈,这是一般开发方式.但是我们在开发项目的 ...
- TestNG测试框架在基于Selenium进行的web自动化测试中的应用
转载请注明出自天外归云的博客园:http://www.cnblogs.com/LanTianYou/ TestNG+Selenium+Ant TestNG这个测试框架可以很好的和基于Selenium的 ...
- Mysql-学习笔记(==》函数的建立与使用 十)
函数的建立与使用 USE db;SELECT sname,sscore,CASE WHEN sscore>=90 THEN '优秀'WHEN sscore>=70 THEN '良好'WHE ...
- iptraf:TCP/UDP网络监控工具
原文:http://www.unixmen.com/iptraf-tcpudp-network-monitoring-utility/ 作者: Enock Seth Nyamador 译文:LCTT ...