scala json анализирует и получает вложенный ключ и значение

У меня есть json, как показано ниже,

У меня есть json, как показано ниже, мне нужно извлечь из них значение

{
    "filed1": "value1",
    "message": {
        "payload": [{
            "type": ["Extra","ID"],
             info": {
                "value": 8
            }
        }, {
            "type": ["Free"],
            info": {
                "value": 99
            }
        }, {
            "type": ["Actual"],
             info": {
                "value": 100
            }
        }]
    },
    "code": "0000"
}


{
    "filed1": "value1",
    "message": {
        "payload": [{
            "type": ["Extra", "new"],
            "value": 9
        }]
    },
    "code": "0001"
}

из двух вышеупомянутых типов json.

Если входной json имеет список ключей type, найдите поле типа, в котором есть элемент Extra, и получите значение внутри info

Если входной json имеет один ключ type, проверьте поле типа, если в нем есть элемент Extra, и получите прямой va; ue

Я пытаюсь, как показано ниже, для типа, но не для списка типов json, то есть первого ввода json

import org.json4s._
import org.json4s.jackson.JsonMethods._
import org.json4s.JsonDSL._

val json = parse(myjsonString, true)
val field = compact(render(json \\ "type"))

val ok = field.contains("[\"Extra\"")

if(ok == true){
println("value " +  compact(render(json \\ "value")))
}

person maanvitha ITService    schedule 03.10.2018    source источник


Ответы (1)


Вам нужно использовать json4s, чтобы делать работу за вас. В частности, вам нужно использовать метод extract для json, чтобы преобразовать его в вашу конкретную структуру данных. Как только вы это сделаете, вы можете обработать его как типы Scala.

Это моя попытка сопоставить структуру вашего JSON с классами случаев Scala:

case class PayloadInfo(value: Int)
case class Payload(`type`: List[String], info: PayloadInfo)
case class Message(payload: List[Payload])
case class Full(filed1: String, message: Message, code: String)

implicit val formats = DefaultFormats

val json = parse(myjsonString, true)

val full = json.extract[Full]

val res = full.message.payload.filter(_.`type`.contains("Extra"))

[Обратные кавычки вокруг type обязательны, потому что это зарезервированное слово]

Возможно, я немного ошибся в типах, но это должно дать вам представление о том, как это сделать.

Вы также можете обработать JValue напрямую, но это будет намного сложнее.

person Tim    schedule 03.10.2018