有人可以给我看一个嵌套 GroupBy 扩展方法的简单示例吗?我正在尝试将一个对象分组到一个列表中。我认为它看起来像这样:
//代码
List<stats> myStats = GetStatsList().GroupBy( d => d.date).GroupBy(t => t.team)
Select(s => new stats
{
Date =
Team =
}).AsEnumerable().ToList();
那这个呢:
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();
我假设你想要这个:
List<stats> myStats = GetStatsList()
.GroupBy(s => new{ s.Date, s.Team})
.Select(g => new stats
{
Date = g.Key.Date,
Team = g.Key.Team,
}).ToList();
我按匿名类型和您想在不同GroupBy
s 中使用的两个属性进行分组。然后我可以通过Group.Key.PropertyName
.
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();