[英]LINQ query (group by groups of items)
我有一点问题。 我有一些指标的数据库表,看起来像:
我想获取RED组的列表,最后获得每个组的开始和结束(这是最简单的部分)。 你有什么想法吗?
您可以使用此扩展方法来创建满足您的谓词的序列组
public static IEnumerable<IEnumerable<T>> GroupBySequence<T>(
this IEnumerable<T> source, Func<T, bool> predicate)
{
var iterator = source.GetEnumerator();
List<T> group = new List<T>();
while (iterator.MoveNext())
{
if (predicate(iterator.Current))
{
group.Add(iterator.Current);
continue;
}
if (group.Any())
{
yield return group;
group = new List<T>();
}
}
if (group.Any())
yield return group;
}
用法:
int[] data = { 1, 2, 1, 2, 2, 2, 1 };
var groups = data.GroupBySequence(i => i == 2); // returns [2] and [2,2,2]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.