シーケンスで並べられたテーブルの名前を持つリスト (myList) があります。MyObject には、Table (文字列) と Sequence (int) の 2 つのプロパティがあります。
List<MyObject>
例:
List<MyObject>[0] = MyObject.Sequence = 0, MyObject.Table = "Cat"
List<MyObject>[1] = MyObject.Sequence = 1, MyObject.Table = "Dog"
List<MyObject>[2] = MyObject.Sequence = 2, MyObject.Table = "Bird"
List<MyObject>[3] = MyObject.Sequence = 3, MyObject.Table = "Fish"
次に、値としてテーブルと EntityObject を持つ構造体キーを持つディクショナリを取得したため、このディクショナリには、このような 10 個のオブジェクト値が既に入力されています。
dict[0] = key (ID = 1, Table = "Cat" ), EntityObject = Cat
dict[1] = key (ID = 2, Table = "Dog"), EntityObject = Dog
dict[2] = key (ID = 3, Table = "Bird"), EntityObject = Bird
dict[3] = key (ID = 4, Table = "Fish"), EntityObject = Fish
dict[4] = key (ID = 5, Table = "Cat" ), EntityObject = Cat
dict[5] = key (ID = 6, Table = "Dog"), EntityObject = Dog
dict[6] = key (ID = 7, Table = "Cat" ), EntityObject = Cat
dict[7] = key (ID = 8, Table = "Dog"), EntityObject = Dog
dict[8] = key (ID = 9, Table = "Cat" ), EntityObject = Cat
dict[9] = key (ID = 10, Table = "Fish"), EntityObject = Fish
だから、テーブルシーケンスを含むリストに従って辞書を並べ替え、辞書を再構築してこのようにしたい
dict[0] = key (ID = 1, Table = "Cat"), EntityObject = Cat
dict[1] = key (ID = 5, Table = "Cat"), EntityObject = Cat
dict[2] = key (ID = 7, Table = "Cat"), EntityObject = Cat
dict[3] = key (ID = 9, Table = "Cat"), EntityObject = Cat
dict[4] = key (ID = 2, Table = "Dog"), EntityObject = Dog
dict[5] = key (ID = 6, Table = "Dog"), EntityObject = Dog
dict[6] = key (ID = 8, Table = "Dog"), EntityObject = Dog
dict[7] = key (ID = 3, Table = "Bird"), EntityObject = Bird
dict[8] = key (ID = 4, Table = "Fish"), EntityObject = Fish
dict[9] = key (ID = 10, Table = "Fish"), EntityObject = Fish
foreach でループを回避し、新しい辞書を再作成してから、既存の辞書にコピーまたは複製したいと考えています。それで、私はこれを一瞬飛ばしてみましたが、いつも同じソートされていないリストを取得しました. Sort または OrderBy メソッドが欠落している可能性がありますが、誰かがこれを修正するのに役立ちます。提案?
Dictionary<MyStruct, EntityObject> dict = this.GetDictionary()
.ToList()
.FindAll(x => x.Key.Table == myList.Find(y => y.Table == x.Key.Table).Table)
.ToDictionary(a => a.Key, b => b.Value);
ノート:
ディクショナリをソートできないことは既に知っていますが、私のアプローチを見ると、新しいディクショナリを再作成して、メモリ内の要素を並べ替えて「dict」に割り当てようとしています。
- -編集 - -
最近この変更を加えましたが、まだ何もありません。助けてください。
Dictionary<MyStruct, EntityObject>
dict = this.GetDictionary()
.ToList()
.OrderBy(x => x.Key.Table == myList
.Find(z => z.Table == x.Key.Table).Table)
.ToDictionary(x => x.Key, y => y.Value);