![](/img/trans.png)
[英]How to convert Future[Seq[A]] into Map[String, Seq[A]]?
[英]Convert Seq[Seq[String,String]] to Map[String,Seq[String]]
我需要轉換這種結構
val seq = Seq(Seq("a","aa"), Seq("b","bb"), Seq("a", "a2"), Seq("b","b2") )
到此地圖:
val map2 = Map ( "a" -> Seq("aa","a2"), "b" -> Seq("bb","b2") )
無法使用toMap
因為它僅適用於Tuple2作為輸入。 任何想法如何解決這個問題?
您可以先按每個子序列的第一項分組,然后映射結果分組值以僅保留子序列的第二個元素:
Seq(Seq("a","aa"), Seq("b","bb"), Seq("a", "a2"), Seq("b","b2") )
.groupBy(_(0)) // Map(b -> List(List(b, bb), List(b, b2)), a -> List(List(a, aa), List(a, a2)))
.mapValues(_.map(_(1))) // Map(b -> List(bb, b2), a -> List(aa, a2))
返回:
Map(b -> List(bb, b2), a -> List(aa, a2))
相似: .groupBy(_.head).mapValues(_.map(_.last))
使用_(0)
和_(1)
您還可以使用.groupBy(_.head).mapValues(_.map(_.last))
這樣可以使mapValues
部分更加明確:
.mapValues{
case valueLists => // List(List(b, bb), List(b, b2))
valueLists.map{
case List(k, v) => v // List(b, bb) => bb
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.