【发布时间】:2013-11-13 17:08:00
【问题描述】:
我有一张地图 X,我正在尝试获取一组满足特定条件的键,如下所示:
Map.Keys X
|> Set.filter (fun x -> ...)
...但我找不到从 F# 的 Map 集合中获取密钥的方法。
【问题讨论】:
我有一张地图 X,我正在尝试获取一组满足特定条件的键,如下所示:
Map.Keys X
|> Set.filter (fun x -> ...)
...但我找不到从 F# 的 Map 集合中获取密钥的方法。
【问题讨论】:
首先将您的map 转换为元组序列(key,value),然后将其映射到仅键的序列:
map |> Map.toSeq |> Seq.map fst
FSI 样本:
>Map.ofList[(1,"a");(2,"b")] |> Map.toSeq |> Seq.map fst;;
val it : seq<int> = seq [1; 2]
或者,由于键的顺序可能无关紧要,您可以使用更急切的方法返回所有键的list。把它做成Microsoft.FSharp.Collections.Map模块的扩展方法keys也不难:
module Map =
let keys (m: Map<'Key, 'T>) =
Map.fold (fun keys key _ -> key::keys) [] m
【讨论】:
Map.filter 更有效地解决了整个原始问题。同样对于我建议的方法,过滤可能会融合到fold,如let filterKeys<'K,'T when 'K: comparison> (p: ('K -> bool)) (m: Map<'K,'T>) = m |> Map.fold (fun ks k _ -> if (p k) then k::ks else ks) []
对于一组键,您可以这样做:
let keys<'k, 'v when 'k : comparison> (map : Map<'k, 'v>) =
Map.fold (fun s k _ -> Set.add k s) Set.empty map
【讨论】:
在 F# 6.0 中,Map 集合现在有一个 Keys property。
老答案:
最易读(并且可能是最有效的,因为不需要先前转换为 Seq 或映射)答案:
let Keys(map: Map<'K,'V>) =
seq {
for KeyValue(key,value) in map do
yield key
} |> Set.ofSeq
【讨论】: