Frage

Wie kann ich ein Wörterbuch in eine Sequenz "konvertieren", damit ich nach Schlüsselwert sortieren kann?

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 ...))
War es hilfreich?

Lösung

Ein System.Collections.Dictionaryu003CK,V> ist ein Ienumerable u003CKeyValuePairu003CK,V> >, und das F# Active Muster 'KeyValue' ist nützlich, um KeyValuePair -Objekte aufzubrechen, also:

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)

Andere Tipps

Sie können auch das finden dict Funktion nützlich. Sei F# eine Typ -Schlussfolgerung für dich:

let results = dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]

> val results : System.Collections.Generic.IDictionary<string,int>

Eine andere Option, die bis zum Ende keine Lambda benötigt

dict ["George", 10; "Peter", 5; "Jimmy", 9; "John", 2]
|> Seq.map (|KeyValue|)
|> Seq.sortBy fst
|> Seq.iter (fun (k,v) -> ())

mit Hilfe von https://gist.github.com/theburningmonk/3363893

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top