Jat*_*tin 21
对于一个嵌套列表:
flatten将执行:
scala> List(List(1), List(2), List(3)).flatten
res4: List[Int] = List(1, 2, 3)
scala> List(List(List(1)), List(List(2)), List(List(3))).flatten
res5: List[List[Int]] = List(List(1), List(2), List(3))
Run Code Online (Sandbox Code Playgroud)
对于多个嵌套列表,您可以:
def flatten(ls: List[Any]): List[Any] = ls flatMap {
case i: List[_] => flatten(i)
case e => List(e)
}
val k = List(1, List(2, 3), List(List(List(List(4)), List(5)), List(6, 7)), 8)
flatten(k)
Run Code Online (Sandbox Code Playgroud)
它打印 List[Any] = List(1, 2, 3, 4, 5, 6, 7, 8)
Ben*_*mes 14
从您粘贴的错误中,您似乎正在尝试调用flatten嵌套列表本身的实例方法.这需要一个隐式转换,以使IterableList包含的任何类型的类型.在您的情况下,看起来编译器找不到一个.
使用flatten从List单独的对象,它不需要隐含参数:
scala> val foo = List(List(1), List("a"), List(2.3))
foo: List[List[Any]] = List(List(1), List(a), List(2.3))
scala> List.flatten(foo)
res1: List[Any] = List(1, a, 2.3)
Run Code Online (Sandbox Code Playgroud)
只是用foo.flatten.
如果我们有一个例子会有所帮助。您的代码应该类似于:
val f = List(1, 2)
val s = List(3, 4)
val top = List(f, s)
List.flatten(top) // returns List(1, 2, 3, 4)
Run Code Online (Sandbox Code Playgroud)