如何展平猫的 ValidatedNel 值序列
How to flatten a sequence of cats' ValidatedNel values
我需要将一系列 cats.data.ValidatedNel[E, T]
值扁平化为单个 ValidatedNel
值:
val results: Seq[cats.data.ValidatedNel[E, T]] = ???
val flattenedResult: cats.data.ValidatedNel[E, T]
我可以这样做:
import cats.std.list._, cats.syntax.cartesian._
results.reduce(_ |@| _ map { case _ => validatedValue })
但想知道是否存在预定义的库方法。
这取决于你想如何组合它们(你的问题中的 validatedValue
是什么?)
import cats.data.{Validated, ValidatedNel}
import cats.implicits._
val validations1 = List(1.validNel[String], 2.valid, 3.valid)
val validations2 = List(1.validNel[String], "kaboom".invalidNel, "boom".invalidNel)
如果你想合并 T
s,你可以使用 Foldable.combineAll
,它使用 Monoid[T]
:
val valSum1 = validations1.combineAll
// Valid(6)
val valSum2 = validations2.combineAll
// Invalid(OneAnd(kaboom,List(boom)))
如果你想得到一个ValidationNel[String, List[T]]
,你可以使用Traverse.sequence
:
val valList1: ValidatedNel[String, List[Int]] = validations1.sequence
// Valid(List(1, 2, 3))
val valList2: ValidatedNel[String, List[Int]] = validations2.sequence
// Invalid(OneAnd(kaboom,List(boom)))
如果你不在乎结果,好像是这样,你可以使用Foldable.sequence_
。
val result1: ValidatedNel[String, Unit] = validations1.sequence_
// Valid(())
val result2: ValidatedNel[String, Unit] = validations2.sequence_
// Invalid(OneAnd(kaboom,List(boom)))
validations1.sequence_.as(validatedValue) // as(x) is equal to map(_ => x)
我需要将一系列 cats.data.ValidatedNel[E, T]
值扁平化为单个 ValidatedNel
值:
val results: Seq[cats.data.ValidatedNel[E, T]] = ???
val flattenedResult: cats.data.ValidatedNel[E, T]
我可以这样做:
import cats.std.list._, cats.syntax.cartesian._
results.reduce(_ |@| _ map { case _ => validatedValue })
但想知道是否存在预定义的库方法。
这取决于你想如何组合它们(你的问题中的 validatedValue
是什么?)
import cats.data.{Validated, ValidatedNel}
import cats.implicits._
val validations1 = List(1.validNel[String], 2.valid, 3.valid)
val validations2 = List(1.validNel[String], "kaboom".invalidNel, "boom".invalidNel)
如果你想合并 T
s,你可以使用 Foldable.combineAll
,它使用 Monoid[T]
:
val valSum1 = validations1.combineAll
// Valid(6)
val valSum2 = validations2.combineAll
// Invalid(OneAnd(kaboom,List(boom)))
如果你想得到一个ValidationNel[String, List[T]]
,你可以使用Traverse.sequence
:
val valList1: ValidatedNel[String, List[Int]] = validations1.sequence
// Valid(List(1, 2, 3))
val valList2: ValidatedNel[String, List[Int]] = validations2.sequence
// Invalid(OneAnd(kaboom,List(boom)))
如果你不在乎结果,好像是这样,你可以使用Foldable.sequence_
。
val result1: ValidatedNel[String, Unit] = validations1.sequence_
// Valid(())
val result2: ValidatedNel[String, Unit] = validations2.sequence_
// Invalid(OneAnd(kaboom,List(boom)))
validations1.sequence_.as(validatedValue) // as(x) is equal to map(_ => x)