8

也许我想念使用?(我有使用 System.Li)。没有Distinct问题。

这是我要添加 DistinctBy 的命令

 List<Capture> list = db.MyObject.Where(x => x.prop == "Name").ToList();
4

3 回答 3

27

您可以添加扩展方法

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();

或者,您可以使用DistincyBy通过MoreLinq提供的。

于 2013-11-10T13:34:56.727 回答
2

另一个例子:

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;
            }
        }
    }
}
于 2015-06-02T16:39:56.750 回答
1
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
于 2017-11-03T06:13:10.193 回答