"Two", 3 -> "Three") val m2 = Map(2 -> 2.0, 3 -> 3.0-6ren">
gpt4 book ai didi

scala - Scala 中两个 map 的交集和合并/连接

转载 作者:行者123 更新时间:2023-12-02 21:00:47 25 4
gpt4 key购买 nike

假设我有两张类似这样的 map 。

val m1 = Map(1 -> "One", 2 -> "Two", 3 -> "Three")
val m2 = Map(2 -> 2.0, 3 -> 3.0, 4 -> 4.0)

我想根据键获取交集并返回一个表示合并值的元组。结果看起来像这样。

Map(2 -> (Two,2.0), 3 -> (Three,3.0))

我想我可以采取类似的措施

val merged = m1 collect {
case (key, value) if m2.contains(key) => key -> (value, m2(key))
}

但是有没有“更惯用”的方法来做到这一点?我的直觉与我使用 Set

得到的直觉类似
val merged = m1.intersect(m2)

最佳答案

m1.keySet.intersect(m2.keySet).map(k => k->(m1(k),m2(k))).toMap
// res0: Map[Int,(String, Double)] = Map(2 -> (Two,2.0), 3 -> (Three,3.0))

获取键的交集,然后将它们映射到一个新的Map中。

关于scala - Scala 中两个 map 的交集和合并/连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46552478/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com