我有两节课:
class Foo { public Bar SomeBar { get; set; } } class Bar { public string Name { get; set; } }
我有一个组合在一起的Foos列表:
var someGroup = from f in fooList orderby f.SomeBar.Name ascending group f by f.SomeBar.Name into Group select Group;
如何从someGroup获取不同Bars的列表?
是否可能存在多个具有相同名称的Bar?如果是这样,那很棘手.如果没有,您可以将其更改为:
var grouped = from f in fooList orderby f.SomeBar.Name ascending group f by f.SomeBar into Group select Group; var bars = grouped.Select(group => group.Key);
或者,如果您只需要每个名称一个条,您可以坚持使用原始查询,但更改最后一位:
var someGroup = from f in fooList orderby f.SomeBar.Name ascending group f by f.SomeBar.Name into Group select Group; var bars = someGroup.Select(group => group.First().SomeBar);
这将采用每组中的第一个Foo,并找到它的Bar.