다음을 수행하면 :
import org.json4s.DefaultFormats
import org.json4s.jackson.Serialization.{read, write}
implicit val formats = DefaultFormats
val tuple = (5.0, 5.0)
val json = write(tuple)
println("Write: " + json)
println("Read: " + read[(Double, Double)](json))
다음 출력이 표시됩니다.
Write: {"_1$mcD$sp":5.0,"_2$mcD$sp":5.0}
Exception in thread "main" org.json4s.package$MappingException: No usable value for _1
Did not find value which can be converted into double
at org.json4s.reflect.package$.fail(package.scala:95)
at org.json4s.Extraction$ClassInstanceBuilder.org$json4s$Extraction$ClassInstanceBuilder$$buildCtorArg(Extraction.scala:548)
at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$3.applyOrElse(Extraction.scala:572)
at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$3.applyOrElse(Extraction.scala:570)
at scala.PartialFunction.$anonfun$runWith$1$adapted(PartialFunction.scala:145)
at scala.collection.mutable.ResizableArray.foreach(ResizableArray.scala:62)
at scala.collection.mutable.ResizableArray.foreach$(ResizableArray.scala:55)
at scala.collection.mutable.ArrayBuffer.foreach(ArrayBuffer.scala:49)
at scala.collection.TraversableLike.collect(TraversableLike.scala:406)
at scala.collection.TraversableLike.collect$(TraversableLike.scala:404)
at scala.collection.AbstractTraversable.collect(Traversable.scala:108)
at org.json4s.Extraction$ClassInstanceBuilder.instantiate(Extraction.scala:570)
at org.json4s.Extraction$ClassInstanceBuilder.result(Extraction.scala:630)
at org.json4s.Extraction$.$anonfun$extract$10(Extraction.scala:416)
at org.json4s.Extraction$.$anonfun$customOrElse$1(Extraction.scala:637)
at scala.PartialFunction.applyOrElse(PartialFunction.scala:127)
at scala.PartialFunction.applyOrElse$(PartialFunction.scala:126)
at scala.PartialFunction$$anon$1.applyOrElse(PartialFunction.scala:257)
at org.json4s.Extraction$.customOrElse(Extraction.scala:637)
at org.json4s.Extraction$.extract(Extraction.scala:408)
at org.json4s.Extraction$.extract(Extraction.scala:40)
at org.json4s.ExtractableJsonAstNode.extract(ExtractableJsonAstNode.scala:21)
at org.json4s.jackson.Serialization$.read(Serialization.scala:50)
at org.json4s.Serialization.read(Serialization.scala:25)
at org.json4s.Serialization.read$(Serialization.scala:25)
at org.json4s.jackson.Serialization$.read(Serialization.scala:17)
내 종속성에 다음을 포함했습니다.
"com.fasterxml.jackson.module" %% "jackson-module-scala" % "2.11.3",
"org.json4s" %% "json4s-jackson" % "3.6.10",
"org.json4s" %% "json4s-ext" % "3.6.10",
기능입니까, 버그입니까?
잘못된 JSON을 만들려고하기 때문에 이것이 기능이라고 생각합니다. 두 배의 튜플을 직렬화하고 싶지만 작성 후 무엇을 얻고 싶습니까? JSON은 다음과 같이 보입니다. { 5.0 : 5.0 }
이는 유효하지 않으며 키 는 double
. 튜플의 첫 번째 유형을 바꾸면 String
올바르게 작동합니다.
val tuple: (String, Double) = ("5.0", 5.0)
val json = write(tuple)
println("Write: " + json) // Write: {"5.0":5.0} - this is valid JSON
println("Read: " + read[(String, Double)](json))
// Read: (5.0,5.0) // and type will be (String, Double)
따라서 JSON의 키 유형과 유효하지 않은 경우에주의하십시오.
여기 Json4s에서 한 가지 혼란 스럽습니다. 오류 메시지입니다. 정말 끔찍합니다.
이 기사는 인터넷에서 수집됩니다. 재 인쇄 할 때 출처를 알려주십시오.
침해가 발생한 경우 연락 주시기 바랍니다[email protected] 삭제
몇 마디 만하겠습니다