Si sólo desea que el usuario pura LINQ, puede utilizar GroupBy:
List<obj> distinct =
objs.GroupBy(car => car.typeID).Select(g => g.First()).ToList();
Si quieres un método que se utiliza en todo a través de la aplicación:
public static IEnumerable<TSource> DistinctBy<TSource, TKey>
(this IEnumerable<TSource> source, Func<TSource, TKey> keySelector)
{
HashSet<TKey> seenKeys = new HashSet<TKey>();
foreach (TSource element in source)
{
if (!seenKeys.Contains(keySelector(element)))
{
seenKeys.Add(keySelector(element));
yield return element;
}
}
}
como MoreLinq ¿el
uso de este método para encontrar los valores distintos utilizando sólo la propiedad Id, se puede utilizar:
var query = objs.DistinctBy(p => p.TypeId);
puede utilizar varias propiedades:
var query = objs.DistinctBy(p => new { p.TypeId, p.Name });
La segunda forma parece usar una sobrecarga de distinta que no existe por lo que yo sé. –
Vaya, elimine el segundo, gracias @Jon Skeet, que se puede hacer con IEqualityComparer –
Como mencionó Jon Skeet, esto solo devolverá las propiedades especificadas en el Seleccionar. –