Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/scala/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将嵌套映射中的所有键转换为Scala中的驼峰大小写_Scala - Fatal编程技术网

将嵌套映射中的所有键转换为Scala中的驼峰大小写

将嵌套映射中的所有键转换为Scala中的驼峰大小写,scala,Scala,我有一张这样的地图: Map("first_key"->"first_value", "second_key"->Map("second_first_key"->"second_first_value")) 如何在scala中递归地将所有键转换为如下所示: Map("firstKey"->"first_value", "secondKey"->Map("secondFirstKey"->"second_first_value")) 这应该满

我有一张这样的地图:

Map("first_key"->"first_value",
    "second_key"->Map("second_first_key"->"second_first_value"))
如何在scala中递归地将所有键转换为如下所示:

Map("firstKey"->"first_value",
    "secondKey"->Map("secondFirstKey"->"second_first_value"))

这应该满足您的要求:

def convert(m: Map[String, Any]): Map[String, Any] = {
  m.map {
    case (k, v) =>
      val k2 = toCamel(k)
      val v2: Any = v match {
        case s: String => s
        case x: Map[String, Any] => convert(x)
      }
      k2 -> v2
  }
}

def toCamel(s: String): String = {
  val split = s.split("_")
  val tail = split.tail.map { x => x.head.toUpper + x.tail }
  split.head + tail.mkString
}

val m = Map("first_key"->"first_value",
            "second_key"->Map("second_first_key"->"second_first_value"))

convert(m)
// Map(firstKey -> first_value, secondKey -> Map(secondFirstKey -> second_first_value))