也许我错过了使用? (我使用System.Li)。
Distinct
没问题。
这是我想添加DistinctBy
的命令 List<Capture> list = db.MyObject.Where(x => x.prop == "Name").ToList();
答案 0 :(得分:16)
您可以添加扩展方法
public static IEnumerable<T> DistinctBy<T, TKey>(this IEnumerable<T> items, Func<T, TKey> property)
{
return items.GroupBy(property).Select(x => x.First());
}
你可以像
一样使用它 List<Capture> list = db.MyObject.Where(x => x.prop == "Name")
.DistinctBy(y=> y.prop )
.ToList();
或者,您可以使用MoreLinq提供的DistincyBy
。
答案 1 :(得分:1)
另一个例子:
public static class ExtensionMethods
{
public static IEnumerable<TSource> DistinctBy<TSource, TKey>(this IEnumerable<TSource> source, Func<TSource, TKey> keySelector)
{
var seenKeys = new HashSet<TKey>();
foreach (TSource element in source)
{
if (seenKeys.Add(keySelector(element)))
{
yield return element;
}
}
}
}
答案 2 :(得分:0)
MyList.GroupBy(a=>a.item).select(a=>a.FirstOrDefault()).ToList();//use this
//is equal to
MyList.DistinctBy(a=>a.item).ToList();//its not work with linq