首页 > 解决方案 > 如何将 Flow[T, Seq[Seq[String]], NotUsed] 展平为 Flow[T, Seq[String], NotUsed]

问题描述

我有一个 Flow[T, Seq[Seq[String]], NotUsed] 类型的流。

我想以示例流的方式将其展平

ev1: Seq(Seq("a", "b"), Seq("n", "m")
ev2: Seq(Seq("x", "y"))

应该变成以下流:

ev1: Seq("a", "b")
ev2: Seq("n", "m")
ev3: Seq("x", "y")

标签: akka-stream

解决方案


使用mapConcat(identity)

  implicit val actorSystem = ActorSystem()
  implicit val materializer = ActorMaterializer()

  val events = Vector(
    Vector(Vector(1, 2), Vector(3, 4)),
    Vector(Vector(5, 6))
  )

  Source.apply(events)
    .mapConcat(identity)
    .runForeach(println)

  actorSystem.terminate()

印刷

Vector(1, 2)
Vector(3, 4)
Vector(5, 6)

通常,mapConcat您可以将事件序列展平为主流。


推荐阅读