这个问题类似于LINQ group one type of item,但是以更通用的方式处理。

我有一个列表,其中包含各种派生类。我可能有这样的事情:

List<BaseClass> list = new List<BaseClass>() {
  new Class1(1),
  new Class2(1),
  new Class1(2),
  new Class3(1),
  new Class2(2),
  new Class4(1),
  new Class3(2)
};

我正在尝试使用LINQ对列表进行半排序,以便对某些具有base.GroupThisType == true的类保持自然顺序。具有GroupThisType的所有类都应在同一类型的第一个类出现的位置分组在一起。输出如下所示:
List<BaseClass> list = new List<BaseClass>() {
  new Class1(1),
  new Class1(2),
  new Class2(1),
  new Class3(1),
  new Class3(2)
  new Class2(2),
  new Class4(1),
};

编辑:糟糕,忘了说这个结果是假设的(Class1和Class3)。GroupThisType== true

最佳答案

像这样:

list = list.Select((o, i) => new { Index = i * 10000, Value = o })
           .GroupBy(q => q.GetType())
           .SelectMany(g => {
               if (g.First().GroupThisType)
                   return g.Select((q, i) =>
                       new { Index = g.First().Index + i, Value = q.Value }
                   );
               else
                   return g;
           })
           .OrderBy(q => q.Index)
           .Select(q => q.Value)
           .ToList();
i * 10000允许在任何两个项目之间插入一个组中的10,000个项目。

您可以将g.First().GroupThisType替换为typesToGroup.Contains(g.Key)

09-26 09:17