LINQ

CheckedListBoxのチェック状態を簡単に取得・設定できるクラスを作成

using System.Linq.Expressions; using System.Windows.Forms; ... public class CheckedListBoxWrapper<T, Tvm, Tdm> { CheckedListBox c; Func<T, Tvm> vmSelector; Func<T, Tdm> dmSelector; // コンストラクタ public CheckedListBoxWrapper(CheckedListBox c) { this.c = c; } // デ</t,></t,></t,>…

グループ化して上位N件ずつ取得

似たような事を既に書いてるけど、懲りずに。■やりたいこと: テーブル(コレクション)TからGでグルーピングしてOで並べ替えて、グループ毎の上位N件ずつだけ取得。T-SQLだとこんな感じか。 SELECT * FROM ( SELECT *, ROW_NUMBER() OVER (PARTITION BY G ORD…

集合論とかの演算をC#(LINQ)でどう書くか考えてみた。

とりあえず 数学記号の表 - Wikipedia に載ってる項目について。■論理演算・量化 論理積 P ∧ Q P && Q 論理和 P ∨ Q P || Q 否定 ¬P !P 全称量化 ∀x ∈ S; P(x) S.All(x => P(x)) 存在量化 ∃ x ∈ S; P(x) S.Any(x => P(x)) 存在量化 ∃x(x ∈ S) S.Any() ■集合…

グループ化してセット演算子を適用する。 4

さらに再考。 ILookupに変換する部分を抽出。これでもうすこし使い勝手が良くなる。■グループ化セット演算 public static class GroupLinqExtensions { // groupのシーケンスをlookupに変換 public static ILookup<TKey, T> GroupToLookup<T, TKey>(this IEnumerable<IGrouping<TKey, T>> source) </igrouping<tkey,></t,></tkey,>…

グループ化してセット演算子を適用する。 3

さらに再考。 メソッドチェーンを繋げていくことを考えると、IEnumerable<IGrouping> を受け取って IEnumerable<IGrouping> を返すのが良い。■グループ化セット演算 public static class LinqExtensions { // グループ化したキーで重複除去 public stati…

グループ化してセット演算子を適用する。 2

再考。さっきよりは良い感じ。 Distinct は IEnumerable<IGrouping> を受け取って、他のセット演算は IEnumerable<IGrouping> を返すのがポイント。■グループ化セット演算 public static class LinqExtensions { // グループ化したキーで重複除去 (sourc…

グループ化してセット演算子を適用する。

要素の同一性を利用するのはDistinctだけじゃなくてセット演算子全部なので、グループ化してセット演算しやすくするクラスを作ってみたけどなんか複雑になっちゃった。■グループ化クラス public class GroupUniverse<T, TKey> { Func<T, TKey> keySelector; GroupSet set; publ</t,></t,>…

欲しかったのはDistinctじゃなくてOverだった。

単純な自作クラスだとpublic propertyが全部一致したら同一と見なすみたいな動作ではないのでDistinctでの重複要素の除外ができない。 これが結構厄介で、Tupleや匿名クラスに入れ替えたりしたけどなんかめんどくさいし、Distinctの拡張も考えてみたけどなん…