首页 > 学院 > 开发设计 > 正文

C#解决LinqOrderBy()失效的小技巧

2019-11-14 15:45:21
字体:
来源:转载
供稿:网友

前言

      前几天的一个数据列表中我用了Linq GroupBy 和OrderBy。 排序在本机正常使用,发到测试后排序死活不对,很是郁闷,总以为是程序问题。于是请教了另外一个同事。有了以下的答案。

 

问题原因和解决方法

    因为服务器装的是英文版操作系统,没有中文包,所以碰见中文排序无法识别,所以使用OrderBy时需要单独处理下。

 

CultureInfo culture = CultureInfo.GetCultureInfo("zh-cn");            List<TeamDto> teamDtos = teams                    .GroupBy(x => new                    {                        x.TestId,                        x.TestName                    })                    .Select(g => new TeamDto()                    {                        TestID = g.Key.TestId,                        Test = g.Key.TestName,                        Teams = g.ToList()                    })                    .OrderBy(t=>t.Test,StringComparer.Create(culture,true))                    .ToList();

 


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表