Помощь в запросе LINQ с группировкой по - PullRequest
2 голосов
/ 05 октября 2010

У меня есть следующий список:

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

Я хочу, чтобы запрос LINQ получил коллекцию в следующем виде:

клавиша ИЛИ операция между сгруппированными элементами, например:

2: false | true  = true

Результат должен быть:

1: true   
2: true   
3: false

Заранее спасибо

1 Ответ

3 голосов
/ 05 октября 2010
// 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) };
...