您可以将地图应用于所有项目,但只关注键:
yourMap.map({ case (a, b) => (f(a), b) })
您可以将f 定义为函数或简单的常量映射,例如:
Map(false -> "String1", true -> "String2")
把它们放在一起:
object HelloWorld {
def main(args: Array[String]) {
val m = Map(false -> List(20, 15, 20, 17), true -> List(50, 25, 45, 21, 100, 2000, 2100))
val f = Map(false -> "String1", true -> "String2")
val x = m.map({ case (a, b) => (f(a), b) })
System.out.println(x)
}
}
产生预期的结果:
Map(String1 -> List(20, 15, 20, 17), String2 -> List(50, 25, 45, 21, 100, 2000, 2100))
如果你喜欢单行,你也可以避免使用单独的地图/功能:
yourMap.map({
x => x match {
case (false, v) => ("String1", v)
case (true, v) => ("String2", v)
}
})
还有一种方法是只处理元组的左侧:
yourMap.map({case (a, b) =>
(a match {
case false => "String1"
case true => "String2"}, b)})
为了完整起见,如果你唯一的元素真的是 true 和 false 你可以这样做:
yourMap.map({case (a, b) => (if (a) "String2" else "String1", b)})