2014-12-15 20 views
13

Jak mogę przekształcić listę krotek List[(A,B)] w krotkę list (List[A], List[B])?Scala przekształcić listę krotek w krotkę list

Próbowałem dla następujących ale wygląda surowy i miałem nadzieję istnieje lepszy sposób to zrobić

val flat: List[AnyRef] = aAndB.map{ x => 
    x.map(y => List(y._1, y._2)) 
    }.flatMap(x => x) 

    val typeA: List[A] = flat.filter { 
    case x: A => true 
    case _ => false 
    }.map(_.asInstanceOf[A])  

    val typeB: List[B] = flat.filter { 
    case x: B => true 
    case _ => false 
    }.map(_.asInstanceOf[B]) 

Odpowiedz

25

Chcesz unzip

scala> List((1,"a"), (3, "b"), (4, "d")).unzip 
res1: (List[Int], List[String]) = (List(1, 3, 4),List(a, b, d)) 

Podobnie istnieje unzip3 dla List[Tuple3[A, B, C]], choć cokolwiek z wyższego arsenału musiałbyś zaimplementować siebie.

scala> List((1,"a", true), (3, "b", false), (4, "d", true)).unzip3 
res2: (List[Int], List[String], List[Boolean]) = (List(1, 3, 4),List(a, b, d),List(true, false, true)) 
+0

Dla wyższych arii można użyć [kolekcji produktów] (https://github.com/marklister/product-collections) –