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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

garfieldzf   2021-03-22 我要评论
想了解解决C#中Linq GroupBy 和OrderBy失效的方法的相关内容吗,garfieldzf在本文为您仔细讲解解决C#中Linq GroupBy 和OrderBy失效的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:c,linq,orderby,linq,orderby,groupby,c,linq,groupby,下面大家一起来学习吧。

发现问题

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

总结

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

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们