Как преобразовать поток Scala FS2 в строку?
Я хочу знать, как преобразовать Scala fs2 Stream в строку, из fs2 github readme пример:
def converter[F[_]](implicit F: Sync[F]): F[Unit] = {
val path = "/Users/lorancechen/version_control_project/_unlimited-works/git-server/src/test/resources"
io.file.readAll[F](Paths.get(s"$path/fs.txt"), 4096)
.through(text.utf8Decode)
.through(text.lines)
.filter(s => !s.trim.isEmpty && !s.startsWith("//"))
.map(line => fahrenheitToCelsius(line.toDouble).toString)
.intersperse("\n")
.through(text.utf8Encode)
.through(io.file.writeAll(Paths.get(s"$path/fs-output.txt")))
.compile.drain
}
// at the end of the universe...
val u: Unit = converter[IO].unsafeRunSync()
Как получить результат в String, а не в другой файл?
1 ответ
Решение
Если вы хотите получить все String
элементы, работающие в вашем потоке, вы можете использовать runFold
материализовать это. Упрощенный пример:
def converter[F[_]](implicit F: Sync[F]): F[List[String]] = {
val path = "/Users/lorancechen/version_control_project/_unlimited-works/git-server/src/test/resources"
io.file.readAll[F](Paths.get(s"$path/fs.txt"), 4096)
.through(text.utf8Decode)
.through(text.lines)
.filter(s => !s.trim.isEmpty && !s.startsWith("//"))
.runFold(List.empty[String]) { case (acc, str) => str :: acc }
}
А потом:
val list: List[String] = converter[IO].unsafeRunSync()
Если у тебя есть Stream[F, String]
, вы можете позвонить .compile.string
чтобы преобразовать ваш поток в F[String]
.
val s: Stream[IO, String] = ???
val io: IO[String] = s.compile.string
val str: String = io.unsafeRunSync()