Разбор динамически названного объекта json в Scala - PullRequest
0 голосов
/ 24 мая 2018

как я могу разобрать этот тип JSON с Spray-JSON?Как объект guid входит в класс case или мне нужно написать какую-нибудь специальную программу чтения?

{
    "referredEntities":{
        "012e2ec1-c205-4657-81d7-1e06eac1a849":{
            "typeName":"type1",
            "attributes":{
                "owner":"dave",
                "qualifiedName":"test",
                "name":"test"...

1 Ответ

0 голосов
/ 24 мая 2018

Предполагая, что ваш объект JSON будет выглядеть примерно так:

{
    "referredEntities": {
        "012e2ec1-c205-4657-81d7-1e06eac1a849":{
            "typeName":"type1",
            "attributes":{
                "owner":"dave",
                "qualifiedName":"test",
                "name":"test"
        }
     },
    "012e2ec1-c205-4657-81d7-1e06ea1234":{
            "typeName":"type2",
            "attributes":{
                "owner":"nicky",
                "qualifiedName":"test1",
                "name":"test22"
        }
     }}
}

Рассмотрим следующее решение:

import spray.json._

val source = """{
               |    "referredEntities":{
               |        "012e2ec1-c205-4657-81d7-1e06eac1a849":{
               |            "typeName":"type1",
               |            "attributes":{
               |                "owner":"dave",
               |                "qualifiedName":"test",
               |                "name":"test"
               |        }
               |     },
               |    "012e2ec1-c205-4657-81d7-1e06ea1234":{
               |            "typeName":"type1",
               |            "attributes":{
               |                "owner":"dave",
               |                "qualifiedName":"test",
               |                "name":"test"
               |        }
               |     }}}""".stripMargin

val jsonAst = source.parseJson

case class Attributes(owner: String, qualifiedName: String, name: String)
case class Entity(typeName: String, attributes: Attributes)
case class ReferredEntity(entityUUID: String, entity: Entity)
case class Source(referredEntities: Seq[ReferredEntity])

object MyJsonProtocol extends  DefaultJsonProtocol {
  implicit val attributesFmt = jsonFormat3(Attributes)
  implicit val entityFmt = jsonFormat2(Entity)

  implicit object SourceJsonFormat extends RootJsonReader[Source] {
    def read(value: JsValue) = value.asJsObject.getFields("referredEntities") match {
      case Seq(obj: JsObject) => Source(obj.fields.toSeq.map(item => ReferredEntity(item._1, entityFmt.read(item._2))))
    }
  }
}

import MyJsonProtocol._

SourceJsonFormat.read(jsonAst)
...