class obj
{
int typeId; //10 types 0-9
string uniqueString; //this is unique
}
objの要素が100個あるリストがありますが、一意のtypeIDは10個だけであると想定します。
オブジェクトのリストから10個の一意のintを返すLINQクエリを作成することは可能ですか?
回答:
objList.Select(o=>o.typeId).Distinct()
完全なオブジェクトが必要であるがtypeID
、によって区別を処理するだけであると仮定すると、これを簡単にするためにLINQに組み込まれているものはありません。(値だけが必要な場合はtypeID
、簡単です。でそれに投影してからSelect
、通常のDistinct
呼び出しを使用します。)
でMoreLINQ我々はDistinctBy
あなたが使用できる演算子を:
var distinct = list.DistinctBy(x => x.typeID);
ただし、これはLINQ toObjectsでのみ機能します。
グループ化またはルックアップを使用できますが、これはやや面倒で非効率的です。
var distinct = list.GroupBy(x => x.typeID, (key, group) => group.First());
純粋なLinqを使用したいだけの場合は、groupbyを使用できます。
List<obj> distinct =
objs.GroupBy(car => car.typeID).Select(g => g.First()).ToList();
MoreLinqと同様に、アプリ全体でメソッドを使用する場合は、次のようにします。
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;
}
}
}
このメソッドを使用して、Idプロパティのみを使用して個別の値を見つけるには、次を使用できます。
var query = objs.DistinctBy(p => p.TypeId);
複数のプロパティを使用できます。
var query = objs.DistinctBy(p => new { p.TypeId, p.Name });
確かに、を使用してくださいEnumerable.Distinct
。
obj
(eg foo
)のコレクションが与えられた場合、次のようにします。
var distinctTypeIDs = foo.Select(x => x.typeID).Distinct();
私はこれがあなたが探しているものだと思います:
var objs= (from c in List_Objects
orderby c.TypeID select c).GroupBy(g=>g.TypeID).Select(x=>x.FirstOrDefault());
.First
何かがなければグループは存在しないので、問題ありません。
GroupBy
これも簡単にすることができます-例については私の答えを参照してください。
ただのLINQを使用する場合は、上書きすることができますのEqualsとGetHashCodeメソッドのメソッドを。
製品クラス:
public class Product
{
public string ProductName { get; set; }
public int Id { get; set; }
public override bool Equals(object obj)
{
if (!(obj is Product))
{
return false;
}
var other = (Product)obj;
return Id == other.Id;
}
public override int GetHashCode()
{
return Id.GetHashCode();
}
}
主な方法:
static void Main(string[] args)
{
var products = new List<Product>
{
new Product{ ProductName="Product 1",Id = 1},
new Product{ ProductName="Product 2",Id = 2},
new Product{ ProductName="Product 4",Id = 5},
new Product{ ProductName="Product 3",Id = 3},
new Product{ ProductName="Product 4",Id = 4},
new Product{ ProductName="Product 6",Id = 4},
new Product{ ProductName="Product 6",Id = 4},
};
var itemsDistinctByProductName = products.Distinct().ToList();
foreach (var product in itemsDistinctByProductName)
{
Console.WriteLine($"Product Id : {product.Id} ProductName : {product.ProductName} ");
}
Console.ReadKey();
}