15

是否有可能(最好使用 LINQ)在组本身内订购一个具有自然分组的集合而不打乱组顺序?

让我解释。我有一个集合:

        List<grpitem> list = new List<grpitem>()
        {
             new grpitem() {groupCode="1", item="a"},
             new grpitem() {groupCode="1", item="b"},
             new grpitem() {groupCode="1", item="c"},
             new grpitem() {groupCode="2", item="a"},
             new grpitem() {groupCode="2", item="c"},
             new grpitem() {groupCode="2", item="b"},
             new grpitem() {groupCode="3", item="c"},
             new grpitem() {groupCode="3", item="b"},
             new grpitem() {groupCode="3", item="a"}
        };

它到达的顺序(groupCode 的顺序)在别处确定。我需要重新排列集合,以便在每个组中,元素按项目值排序,即:

             {groupCode="1", item="a"},
             {groupCode="1", item="b"},
             {groupCode="1", item="c"},
             {groupCode="2", item="a"},
             {groupCode="2", item="b"},
             {groupCode="2", item="c"},
             {groupCode="3", item="a"},
             {groupCode="3", item="b"},
             {groupCode="3", item="c"},

该集合可以同样以 groupCode 顺序“2”、“3”、“1”或其他方式到达。我不能打扰 - 我只需要重新排序每个组中的元素。

LINQ 查询将非常整洁!(我可能是昏暗的,但我还没有找到)

我试过这个:

        var reOrdered = (from x in list
                          group x by x.groupCode into groups
                          select groups)
                         .OrderBy(i => from j in i select j.item)
                         .SelectMany(i => i);

但我得到一个错误 - “至少一个对象必须 IComparable”,这让我感到困惑。

最后,这必须是 .Net3.5 中的 C#,不能再晚了。

4

1 回答 1

24
var ordered = list.GroupBy(grp => grp.groupCode)
   .SelectMany(g => g.OrderBy(grp => grp.item));

这是一个demo带有乱码的样本数据。

于 2013-09-20T12:57:50.840 回答