Wie kann man ein Wörterbuch in eine Sequenz in F#"konvertieren"?
-
12-09-2019 - |
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 ...))
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