2

有人可以给我看一个嵌套 GroupBy 扩展方法的简单示例吗?我正在尝试将一个对象分组到一个列表中。我认为它看起来像这样:

//代码

List<stats> myStats = GetStatsList().GroupBy( d => d.date).GroupBy(t => t.team)
        Select(s => new stats
  {
        Date = 
        Team = 
 }).AsEnumerable().ToList();
4

3 回答 3

2

那这个呢:

    List<stats> myStats = GetStatsList()
                            .GroupBy(s => new { s.date, s.team })
                            .Select(g => new stats { Date = g.Key.date , Team = g.Key.team})
                            .AsEnumerable()
                            .ToList();
于 2013-04-19T09:07:04.130 回答
1

我假设你想要这个:

List<stats> myStats = GetStatsList()
    .GroupBy(s => new{ s.Date, s.Team})
    .Select(g => new stats
      {
            Date = g.Key.Date,
            Team = g.Key.Team,
     }).ToList();

我按匿名类型和您想在不同GroupBys 中使用的两个属性进行分组。然后我可以通过Group.Key.PropertyName.

于 2013-04-19T09:12:17.467 回答
1
var myStats = (from s in GetStatsList()
               group by new { Date = s.date, Team = s.team} into g
               select g.Key).ToList();

请注意,这为您提供了List<T>其中 T 是匿名类型的位置——这可能就足够了。如果您明确需要一个列表,那么:

var myStats = (from s in GetStatsList()
               group by new { s.date, s.team} into g
               select new stat { Date = g.Key.date, Team = g.Key.team}).ToList();
于 2013-04-19T09:14:33.937 回答