给定以下内容:
val t: List[Map[String, Map[String, Int]]] = List(
Map("a" -> Map("m" -> 1, "l" -> 21)),
Map("a" -> Map("m" -> 2, "l" -> 22)),
Map("a" -> Map("m" -> 3, "l" -> 23)),
Map("a" -> Map("m" -> 4, "l" -> 24))
)
我想要结果:
Map(1->21,2->22,3->23,4->24)
到目前为止,我有:
val tt = (for {
(k,v) <- t
newKey = v("m")
newVal = v("l")
} yield Map(newKey -> newVal)).flatten.toMap
但这不是类型检查,因此我无法理解为什么不能缺少基本的理解?
我的问题是:
您有List[Map[...]]
,不是,Map[...]
所以您想先将其拆包。
val tt = (for {
map <- t
(k, v) <- map
} ...)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句