C# DataTable 按数字排序问题

转载自:点击打开链接

用dt.DefaultView.Sort = "RateSort desc"; 方法

排序出来的顺序是1,10,2,20,3,30

而非 1,2,3,10,20,30

解决方案:

按数值排序,可以添加一列转换为数值后的列

dtSum.Columns.Add("RateSort", typeof(int));

将此列的值存放要排序的数值型

例:

dtSum.Columns.Add("Rate");//用于显示

dtSum.Columns.Add("RateSort", typeof(int));//用于排序

double douRate = (douFirstTime / double.Parse(dtSum.Rows[i][1].ToString()))*100;
dtSum.Rows[i]["RateSort"] = douRate;

dtSum.Rows[i]["Rate"] =double.Parse(douRate.ToString("0.00")) +"%";

//绑定

DataView dv = dtSum.DefaultView;
dv.Sort = "RateSort desc";
 this.dgvAgentFirstTime.DataSource = dv.Table;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值