我正在尝试使用List[Either[Int]]
中的Either[List[Int]]
将traverse
转换为cats
。
错误
[error] StringCalculator.scala:19:15: value traverseU is not a member of List[String]
[error] numList.traverseU(x => {
代码
import cats.Semigroup
import cats.syntax.traverse._
import cats.implicits._
val numList = numbers.split(',').toList
numList.traverseU(x => {
try {
Right(x.toInt)
} catch {
case e: NumberFormatException => Left(0)
}
})
.fold(
x => {},
x => {}
)
我也尝试过使用traverse而不是traverseU。
配置(适用于猫)
lazy val root = (project in file(".")).
settings(
inThisBuild(List(
organization := "com.example",
scalaVersion := "2.12.4",
scalacOptions += "-Ypartial-unification",
version := "0.1.0-SNAPSHOT"
)),
name := "Hello",
libraryDependencies += cats,
libraryDependencies += scalaTest % Test
)
答案 0 :(得分:8)
它应该只是traverse
,只要您使用的是最近的猫版本(1.0.x),但是,您无法同时导入cats.syntax
和cats.implicits._
因为他们会发生冲突。
不幸的是,每当Scala编译器看到implicits冲突时,它都会给你一个非常无益的消息。
删除cats.syntax
导入,它应该可以正常工作。
有关详细信息,请查看import guide.
答案 1 :(得分:2)
您只需要cats.implicits._
。 e.g。
import cats.implicits._
val numbers = "1,2,3"
val numList = numbers.split(',').toList
val lst = numList.traverse(x => scala.util.Try(x.toInt).toEither.leftMap(_ => 0))
println(lst)