按值排序地图

Ech*_*cho 5 scala

我有List[(String,String)],我需要按第二个值对它们进行排序并返回一个地图

我做了以下事情:

val newMap = list.sortBy(_._2).foldLeft(Map.empty[String, String]) {
      (map, key) ? map + (key._1 ? key._2)
    }
Run Code Online (Sandbox Code Playgroud)

列表是一个 List[(String,String)]

但是,返回的地图没有排序!!

Tom*_*icz 9

默认Map实现是基于哈希的,它们不保留顺序.而是使用scala.collection.mutable.LinkedHashMap:

val newMap = list.sortBy(_._2).foldLeft(new LinkedHashMap[String, String]) {
    (map, key) => map += (key._1 -> key._2)
    map
}
Run Code Online (Sandbox Code Playgroud)

正如@Rex Kerr所建议的那样,scala.collection.immutable.ListMap对于目标类型可能是更好的选择:

val newMap = list.sortBy(_._2).foldLeft(new ListMap[String, String]) {
    (map, key) => map + (key._1 -> key._2)
}
Run Code Online (Sandbox Code Playgroud)

或者(再次完整的学分应该去@Rex Kerr):

val newMap = new ListMap() ++ list.sortBy(_._2)
Run Code Online (Sandbox Code Playgroud)

但是你真的想要实现什么?看起来您可能选择了错误的数据结构......

  • 你可能`ListMap()++ list.sortBy(_._ 2)`而不是巨大的慢折? (3认同)
  • @oxbow_lakes:我认为这正是OP要求的(基于示例代码) - 来自`key` - >`value`的`Map`,但条目按`value`排序.但是,让OP决定哪个答案是正确的还是澄清的.顺便说一句,我没有低估你的回答,要明确;-). (2认同)
  • 如果使用`immutable.ListMap`,"在插入顺序中"和"已排序"之间的区别就会消失. (2认同)