将Source [ByteString,Future [IOResult]]转换为List [String]

时间:2016-12-09 22:03:09

标签: scala akka akka-stream

我正在尝试读取文件。我需要将这个文件逐行读入列表。

val res: stream.scaladsl.Source[ByteString, Future[IOResult]] = Ftp.fromPath(Paths.get(uri), ftpSettings)

如何将res值转换为List [String]?

1 个答案:

答案 0 :(得分:5)

评论中的流程似乎是一个很好的起点。 尝试并针对Sink.seq运行它。

  val f: Future[Seq[String]] = res
    .via(Framing.delimiter( ByteString("\n"), maximumFrameLength = 256, allowTruncation = true))
    .map(_.utf8String)
    .runWith(Sink.seq)

  val list: Seq[String] = Await.result(f, 10.seconds)