linq DistinctBy未被识别为方法

z5btuh9x  于 2022-12-06  发布在  其他
关注(0)|答案(4)|浏览(169)

也许我错过了使用?(我有使用系统。李)。与Distinct没有问题。
这是我要将DistinctBy加入的命令

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

ldioqlga1#

可以添加扩展方法

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

7ajki6be

7ajki6be2#

另一个示例:

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;
            }
        }
    }
}
3wabscal

3wabscal3#

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

相关问题