gpt4 book ai didi

c# - 使用 group by 帮助 LINQ 查询

转载 作者:行者123 更新时间:2023-11-30 22:43:38 25 4
gpt4 key购买 nike

我有以下列表:

1: true; 
2: false;
2: true;
3: false;
3: false;
3: false;

我想要一个 LINQ 查询来获取如下集合:

key,分组项之间的OR操作,例如:

2: false | true  = true

结果必须是:

1: true   
2: true
3: false

提前致谢

最佳答案

// my sample data
var list = new[] {
new {key = 1, value = true},
new {key = 2, value = false},
new {key = 2, value = true},
new {key = 3, value = false},
new {key = 3, value = false},
new {key = 3, value = false},
};
// the actual code
var groups = from pair in list
group pair by pair.key into grp
orderby grp.Key
select new {
grp.Key,
Value = grp.Aggregate(false, (x, y) => x || y.value)
};
// display the result
foreach (var grp in groups)
{
Console.WriteLine("{0}: {1}", grp.Key, grp.Value);
}

请注意,您也可以使用 Any 进行聚合,其优点是它会更快短路:

      select new { grp.Key, Value = grp.Any(y => y.value) };

关于c# - 使用 group by 帮助 LINQ 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3863429/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com