好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

解决C#中Linq GroupBy 和OrderBy失效的方法

发现问题

在一个数据列表中我用了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();

总结

以上就是这篇文章的全部内容了,希望能对同样遇到这个问题的朋友们有所帮助,如果有疑问大家可以留言交流。

原文链接:http://HdhCmsTestcnblogs测试数据/sword-successful/p/4912111.html

dy("nrwz");

查看更多关于解决C#中Linq GroupBy 和OrderBy失效的方法的详细内容...

  阅读:63次