gpt4 book ai didi

scala - 如果存在隐式 Json 转换器,则进行 2.2 比赛

转载 作者:行者123 更新时间:2023-12-02 21:02:24 26 4
gpt4 key购买 nike

我已将所有 Json 转换器放在一个文件 JsonUtil 中,然后有一个 ConvertToJson 方法,该方法尝试转换传递给 json 的任何对象。

基本上是这样的结构:

implicit val format_A = format[A]
implicit val format_B = format[B]

def convertToJson(o: Any): JsValue =
o match {
case a: A => Json.toJson(a)
case b: B => Json.toJson(b)
case a: Any => Logger.warn("could not convert to json: "+a); JsNull
}

但有更多的格式化程序/案例。当我需要转换时(出于各种原因),我不想导入所有这些隐式。如果存在有效的 toJson 转换,是否有办法进行匹配,这样我就不必编写所有案例?

喜欢:

case o: ExistJsonConversion => Json.toJson(o)

最佳答案

这有效。

  def convertToJson[A](a: A)(implicit ev: Format[A] = null): JsValue = {
if (ev != null) {
Json.toJson(a)(ev)
} else {
println("oops")
JsNull
}
}

下面是一个更好的版本(也许;)

  case class Perhaps[E](value: Option[E]) {
def fold[F](ifAbsent: => F)(ifPresent: E => F): F =
value.fold(ifAbsent)(ifPresent)
}

implicit def perhaps[E](implicit ev: E = null) = Perhaps(Option(ev))

def convertToJson[A](a: A)(implicit p: Perhaps[Format[A]]): JsValue = {
p.fold[JsValue] {
println("oops")
JsNull
} { implicit ev =>
Json.toJson(a)
}
}

关于scala - 如果存在隐式 Json 转换器,则进行 2.2 比赛,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20015658/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com