Доступ к тому же уровню JsonElements при помощи Java - PullRequest
0 голосов
/ 20 мая 2018

У меня есть большой и сложный объект JSON, как показано ниже:

{
    "FDN": [{
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822548"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "FR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969007,
        "DT": "20180504123302006"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822549"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "AR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969008,
        "DT": "20180504123302007"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822550"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "FR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969009,
        "DT": "20180504123302007"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822551"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "AR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969010,
        "DT": "20180504123302008"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822552"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "FR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969011,
        "DT": "20180504123302009"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822553"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "FR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969012,
        "DT": "20180504123302010"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822554"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "FR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969013,
        "DT": "20180504123302010"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822573"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "AR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969065,
        "DT": "20180504080929368"
    }, {
        "OT": 0,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822573"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "AR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969066,
        "DT": "20180504080929369"
    }, {
        "OT": 1,
        "CL": [{
            "K": [{
                "FID": 348,
                "VAL": "20822574"
            }, {
                "FID": "LANGUAGE_ID",
                "VAL": "AR"
            }]
        }],
        "NK": null,
        "SS": 0,
        "ITID": "NEWS",
        "TSID": 44969067,
        "DT": "20180504082130104"
    }]
}

Исходя из этого, мне просто нужно рассмотреть блок "CL" следующим образом:

"CL": [{
                "K": [{
                    "FID": 348,
                    "VAL": "20822573"
                }, {
                    "FID": "LANGUAGE_ID",
                    "VAL": "AR"
                }]
            }],

и проверитьесли LANGUAGE_ID равен «AR», а затем добавить соответствующее значение (20822573) соответствующего ключа «FID: 348» в список.просто пример:

 if(LANGUAGE_ID.equals("AR")){
         IdList.add("20822573");
     }

Я не могу сделать это, потому что оба ключа находятся на одном уровне.

Пока мой код:

public static void main(String[] a) throws IOException {
        FileReader jsonReader = new FileReader(new File("json.json"));
        Gson gson = new Gson();
        Map<String,String> fidMap = new HashMap<String, String>();
        JsonObject jsonObject = gson.fromJson(jsonReader, JsonObject.class);
        JsonArray fdnJsonArray = (JsonArray) jsonObject.get("FDN");

        fdnJsonArray.forEach(jsonElement -> {
            JsonArray clJsonArray = jsonElement.getAsJsonObject().get("CL").getAsJsonArray();
            clJsonArray.forEach(clJsonItem -> {
                JsonArray kJsonArray = clJsonItem.getAsJsonObject().get("K").getAsJsonArray();
                kJsonArray.forEach(kArrayElement -> {
                    String fid = kArrayElement.getAsJsonObject().get("FID").getAsString();
                    if(fid != null && !fid.isEmpty() && fid.equalsIgnoreCase("LANGUAGE_ID")) {
                        String val = kArrayElement.getAsJsonObject().get("VAL").getAsString();
                        System.out.println(fid + ":"+ val);
                    }
                });
            });
        });
    }

Действительно ценю вашу помощьна этом!

1 Ответ

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

Рассмотрите возможность использования jsonpath для этого.Быстрый пример для этой конкретной проблемы, чтобы получить объекты CL, был бы прост как $..CL.Затем вы можете манипулировать возвращенными объектами в простой Java.Вы можете быстро создать прототип этого онлайн здесь .Для дальнейшего уточнения jsonpath для включения идентификатора языка вы можете проверить документацию здесь: http://goessner.net/articles/JsonPath/index.html#e2

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...