我有以下代码
sealed trait DomainValidation {
def errorMessage: String
}
type ValidationResult[A] = ValidatedNel[DomainValidation, A]
val ai:ValidationResult[String] = "big".validNel
val bi:ValidationResult[String] = "leboski".validNel
val l = List(ai,bi)我想把l转换成ValidationResult[List[String]]。我遇到了sequence功能,但是我无法使用sequence,因为有些隐式必须存在,它知道如何处理ValidationResult[A]。但我不知道到底需要什么。我写了以下文章
object helper {
implicit class hello[A](l: List[ValidationResult[A]]) {
def mysequence: ValidationResult[List[A]] = {
val m = l.collect { case Invalid(a) => Invalid(a) }
if (m.isEmpty) l.map { case Valid(a) => a }.validNel
else /* merge the NonEmpty Lists */
}
}
}我能做l.mysequence。但我如何使用猫sequence。
PS:我是scala初学者。学习困难:)。原谅任何不正确的提及。
发布于 2019-01-11 14:29:51
在Scala2.12上,以下内容应如预期的那样工作:
import cats.data.ValidatedNel, cats.syntax.validated._
// Your code:
sealed trait DomainValidation {
def errorMessage: String
}
type ValidationResult[A] = ValidatedNel[DomainValidation, A]
val ai:ValidationResult[String] = "big".validNel
val bi:ValidationResult[String] = "leboski".validNel
val l = List(ai,bi)然后:
scala> import cats.instances.list._, cats.syntax.traverse._
import cats.instances.list._
import cats.syntax.traverse._
scala> l.sequence
res0: ValidationResult[List[String]] = Valid(List(big, leboski))您不显示您的代码,也不解释什么不工作,所以很难诊断您的问题,但它可能是以下问题之一:
.sequence要求在编译器选项中启用-Ypartial-unification。如果使用sbt,可以通过将scalacOptions += "-Ypartial-unification"添加到build.sbt (假设您在2.11.9+上)来做到这一点。List的Traverse实例和Traverse的语法。上面的示例代码包括您需要的两个导入,或者您只需导入cats.implicits._并使您的生活变得简单一些。如果这不是这两件事之一,你可能需要在你的问题中包含更多的细节,这样我们才能有所帮助。
https://stackoverflow.com/questions/54148341
复制相似问题