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 ...))
Était-ce utile?

La solution

A System.Collections.Dictionary est un IEnumerable >, et le F # motif actif 'KeyValue' est utile pour briser des objets KeyValuePair, donc:

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
scroll top