我有两个班级:
class Foo
{
public Bar SomeBar { get; set; }
}
class Bar
{
public string Name { get; set; }
}
我有一份我一起组成的食物清单:
var someGroup = from f in fooList
orderby f.SomeBar.Name ascending
group f by f.SomeBar.Name into Group
select Group;
如何从某些组中获取不同的条形列表?
答案 0 :(得分:7)
是否可能有多个名称相同的栏?如果是这样,那很棘手。如果没有,您可以将其更改为:
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。
答案 1 :(得分:0)
如果您通过Equals
的特殊Bar
实施定义“不同”,则可以使用:
var result = someGroup.SelectMany(x => x.Select(t => t.SomeBar)).Distinct();
答案 2 :(得分:0)
之前人们问过类似的问题,所以我结合了每个人的知识:
var newlist<T2> = oldlist<T1>.GroupBy(g => g.distinct_var).Select(g => g.First()) //a
.Select(r=> new T2() {var1=r.va1, var2=r.var2 ...etc}).ToList(); //b
它的作用是:
一个。第一行选择您选择的不同项目,这就是您想要的。
湾第二行通过构造新的T2列表将旧的type1转换为new type2。
对于你的问题可能过于苛刻,只要砍掉你不需要的东西。