[解決済み] LINQ: 区分された値
2022-05-10 09:08:19
質問
XMLから以下の項目を設定しています。
id category
5 1
5 3
5 4
5 3
5 3
これらの項目を明確にしたリストが必要です。
5 1
5 3
5 4
LINQでカテゴリーとIDを区別するにはどうすればよいですか?
どのように解決するのですか?
複数のフィールドで区別しようとしているのか?その場合は、無名型とDistinct演算子を使えば問題ないはずです。
var query = doc.Elements("whatever")
.Select(element => new {
id = (int) element.Attribute("id"),
category = (int) element.Attribute("cat") })
.Distinct();
もし、「より大きな」型の明確な値のセットを取得しようとしているが、明確さの観点からプロパティのサブセットしか見ていない場合、おそらくは
DistinctBy
で実装されているように
MoreLINQ
において
DistinctBy.cs
:
public static IEnumerable<TSource> DistinctBy<TSource, TKey>(
this IEnumerable<TSource> source,
Func<TSource, TKey> keySelector,
IEqualityComparer<TKey> comparer)
{
HashSet<TKey> knownKeys = new HashSet<TKey>(comparer);
foreach (TSource element in source)
{
if (knownKeys.Add(keySelector(element)))
{
yield return element;
}
}
}
(で渡す場合)。
null
を比較器として指定すると、キータイプに応じたデフォルトの比較器が使用されます)。
関連
-
[解決済み] LINQを使用してList<T>から要素を削除する
-
[解決済み] LINQで複数の "order by "を使用する
-
[解決済み] 特定のプロパティに対するLINQのDistinct()
-
[解決済み] SelectとSelectManyの違い
-
[解決済み] LINQのGroup by
-
[解決済み] ある列に含まれる明確な値の数を求めるSQL
-
[解決済み】LINQでリストをサブリストに分割する
-
[解決済み】IEnumerable vs List - What to Use? どのように動作するのでしょうか?
-
[解決済み】Entity Framework。このコマンドに関連するオープンなDataReaderがすでに存在します。
-
[解決済み] LINQを使用してデータをPivotすることは可能ですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] IEnumerable<T>のforeachのLINQでの等価性
-
[解決済み】linqを使用したSelect distinct [重複]。
-
[解決済み】Lambda式でOrderBy descending?
-
[解決済み】LINQ グループバイをディクショナリーオブジェクトに入れる
-
[解決済み】Entity Framework。このコマンドに関連するオープンなDataReaderがすでに存在します。
-
[解決済み] LINQ-to-SQLとストアドプロシージャの比較?[クローズド]
-
[解決済み] LINQを使用してデータをPivotすることは可能ですか?
-
[解決済み] Linqのgroup byのカウントを持つ
-
[解決済み] IQueryableとIEnumerableの違いは何ですか[重複]。
-
[解決済み] LINQ OrderByとThenByの比較