繁体   English   中英

使用play-json转换JsArray

[英]transform an JsArray with play-json

json转换器中的大多数示例都是关于JsObject的。 我尝试转换JsArray,但收到此错误

val json = Json.parse("""[{"toto":1},{"toto":10},{"tata":2}]"""]


val transformer = (__ \'toto).json.update(__.read[JsNumber].map{o => JsNumber(3)})

json.as[JsArray].map(_.transform(transformer))

错误

java.lang.RuntimeException: expected KeyPathNode
  at play.api.libs.json.JsPath$.step$1(JsPath.scala:147)
  at play.api.libs.json.JsPath$.play$api$libs$json$JsPath$$buildSubPath$1(JsPath.scala:156)
  at play.api.libs.json.JsPath$$anonfun$createObj$1.apply(JsPath.scala:161)
  at play.api.libs.json.JsPath$$anonfun$createObj$1.apply(JsPath.scala:159)
  at scala.collection.IndexedSeqOptimized$class.foldl(IndexedSeqOptimized.scala:57)
  at scala.collection.IndexedSeqOptimized$class.foldLeft(IndexedSeqOptimized.scala:66)
  at scala.collection.mutable.WrappedArray.foldLeft(WrappedArray.scala:35)
  at play.api.libs.json.JsPath$.createObj(JsPath.scala:159)
  at play.api.libs.json.PathReads$$anonfun$jsUpdate$1$$anonfun$apply$15.apply(JsConstraints.scala:86)
  at play.api.libs.json.PathReads$$anonfun$jsUpdate$1$$anonfun$apply$15.apply(JsConstraints.scala:86)
  at play.api.libs.json.JsResult$class.map(JsResult.scala:81)
  at play.api.libs.json.JsSuccess.map(JsResult.scala:9)
  at play.api.libs.json.PathReads$$anonfun$jsUpdate$1.apply(JsConstraints.scala:86)
  at play.api.libs.json.PathReads$$anonfun$jsUpdate$1.apply(JsConstraints.scala:82)
  at play.api.libs.json.Reads$$anon$8.reads(Reads.scala:101)
  at play.api.libs.json.JsValue$class.transform(JsValue.scala:78)
  at play.api.libs.json.JsObject.transform(JsValue.scala:166)
  at $anonfun$1.apply(<console>:21)
  at $anonfun$1.apply(<console>:21)
  at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:245)
  at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:245)
  at scala.collection.immutable.List.foreach(List.scala:381)
  at scala.collection.generic.TraversableForwarder$class.foreach(TraversableForwarder.scala:35)
  at scala.collection.mutable.ListBuffer.foreach(ListBuffer.scala:45)
  at scala.collection.TraversableLike$class.map(TraversableLike.scala:245)
  at scala.collection.AbstractTraversable.map(Traversable.scala:104)
  ... 43 elided

好吧,我不确定您要如何在没有“ toto”键的情况下处理对象,但是也许您可以尝试执行以下操作:

val jsonValues = json.as[JsArray].value

jsonValues.map(_.transform(transformer)).zip(jsonValues).foldLeft(JsArray())
{
  case (array, (transformResult, originalObject)) =>
    transformResult match {
      case JsSuccess(newValue, _) => array :+ newValue
      case err: JsError           => array :+ originalObject
    }
}

结果是:

play.api.libs.json.JsArray = [{"toto":3},{"toto":3},{"tata":2}]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM