Comment « convertir » un dictionnaire en une séquence en F #?
-
12-09-2019 - |
Question
Comment puis-je « convertir » un dictionnaire en une séquence de telle sorte que je peux trier des clés?
let results = new Dictionary() results.Add("George", 10) results.Add("Peter", 5) results.Add("Jimmy", 9) results.Add("John", 2) let ranking = results ??????? |> Seq.Sort ?????? |> Seq.iter (fun x -> (... some function ...))
La solution
A System.Collections.Dictionary
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)
Autres conseils
Vous pouvez également trouver la fonction dict
utile. Soit F # faire une inférence de type pour vous:
let results = dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]
> val results : System.Collections.Generic.IDictionary<string,int>
Une autre option, qui n'a pas besoin d'un lambda jusqu'à la fin
dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]
|> Seq.map (|KeyValue|)
|> Seq.sortBy fst
|> Seq.iter (fun (k,v) -> ())
avec l'aide de https://gist.github.com/theburningmonk/3363893
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow