كيفية "تحويل" القاموس في تسلسل في F #؟
-
12-09-2019 - |
سؤال
كيف يمكنني "تحويل" القاموس في تسلسل حتى أتمكن من الترتيب حسب القيمة الرئيسية؟
اسمحوا النتائج = قاموس جديد () النتائج. Add ("جورج"، 10) النتائج. Add ("بيتر"، 5) النتائج. Add ("Jimmy"، 9) النتائج. Add ("John"، 2) دع الترتيب = النتائج ؟؟؟؟؟؟؟ |> seq.sort ؟؟؟؟؟؟ |> SEQ.iter (متعة X -> (... بعض الوظائف ...))
المحلول
system.collections.dictionary.u003CK,V> هو ienumerable u003CKeyValuePairu003CK,V> >، و F # النشط النشط "KEYVALUE" مفيد لكسر كائنات KeyValuepair، لذلك:
open System.Collections.Generic
let results = new Dictionary<string,int>()
results.Add("George", 10)
results.Add("Peter", 5)
results.Add("Jimmy", 9)
results.Add("John", 2)
results
|> Seq.sortBy (fun (KeyValue(k,v)) -> k)
|> Seq.iter (fun (KeyValue(k,v)) -> printfn "%s: %d" k v)
نصائح أخرى
قد تجد أيضا dict
وظيفة مفيدة. دع F # قم بتنصيص نوع لك:
let results = dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]
> val results : System.Collections.Generic.IDictionary<string,int>
خيار آخر، الذي لا يحتاج إلى Lambda حتى النهاية
dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]
|> Seq.map (|KeyValue|)
|> Seq.sortBy fst
|> Seq.iter (fun (k,v) -> ())
لا تنتمي إلى StackOverflow