在列表List<MyClass> ListOfMyClasses
中,如何使用LINQ获取有多少不同的GroupId
属性值?
public class MyClass
{
public int GroupId;
}
例如,让我们说我们有这个清单:
ListOfMyClasses: {MyClass1 (GroupId = 1), MyClass2 (GroupId = 3), MyClass3 (GroupId = 1)}
这里我们应该得到结果为2(GroupId的两个不同的数字)。
答案 0 :(得分:8)
以下是使用Distinct
执行此操作的一种方法:
ListOfMyClasses.Select(t => t.GroupId).Distinct().Count()
或者您也可以使用GroupBy
:
ListOfMyClasses.GroupBy(t => t.GroupId).Count()
答案 1 :(得分:3)
这应该适合你。
var result = list.Select(x => x.GroupId).Distinct().Count();
首先,您要选出所有GroupId
个。然后你过滤它们是不同的。最后,您将获得这些值的计数。
答案 2 :(得分:0)
此外,只想分享我在所有项目中使用的扩展,它也解决了你的任务
public class EqualityComparer<TEntity, TProperty>: IEqualityComparer<TEntity>
{
private readonly Func<TEntity, TProperty> _property;
public EqualityComparer(Func<TEntity, TProperty> property)
{
_property = property;
}
public bool Equals(TEntity x, TEntity y)
{
return _property(x).Equals(_property.Invoke(y));
}
public int GetHashCode(TEntity obj)
{
return _property(obj).GetHashCode();
}
}
public static class Extensions
{
public static IEnumerable<T> DistinctByProperty<T, TProp>(this IEnumerable<T> source, Func<T, TProp> propertyFunc)
{
return source.Distinct(new EqualityComparer<T, TProp>(propertyFunc));
}
}
它允许您编写ListOfMyClasses.DistinctByProperty(x => x.GroupId).Count()