Доступ к элементу JSON с помощью GSON

У меня очень большой объект 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"
    }]
}

Я хочу получить все элементы, в которых Language_ID = "AR" бывший:

{
   "FID": "LANGUAGE_ID",
   "VAL": "AR"
}

Не могли бы вы показать мне, как это сделать?

Пока мой код:

 JsonArray jsonArray = (JsonArray) convertedObject.get("FDN");
                    System.out.println("jsonArray>" + jsonArray.size());
                    List<JsonElement> CL= new ArrayList<JsonElement>();
                    for(int x=0; x < jsonArray.size(); x++){
                        JsonObject jObject4 = (JsonObject) jsonArray.get(x);   
                        JsonElement e = jObject4.get("CL");                    
                        CL.add(jObject4.get("CL"));
                    }
                    System.out.println("CL>" + CL.get(0));

Я только что напечатал первый элемент, и это примерно так:

[{"K":[{"FID":2085,"VAL":"148433"},{"FID":"LANGUAGE_ID","VAL":"EN"}]}]

Пожалуйста, покажите мне способ получить доступ к LANGUAGE_ID этой структуры.

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
0
734
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вот код для доступа к FID, значение которого "LANGUAGE_ID", а также соответствующий VAL.

public class GSONReading {
    public static void main(String[] a) throws IOException {
        FileReader jsonReader = new FileReader(new File("json.json"));
        Gson gson = new Gson();
        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);
                    }
                });
            });
        });
    }
}

Выход:

LANGUAGE_ID:FR
LANGUAGE_ID:AR
LANGUAGE_ID:FR
LANGUAGE_ID:AR
LANGUAGE_ID:FR
LANGUAGE_ID:FR
LANGUAGE_ID:FR
LANGUAGE_ID:AR
LANGUAGE_ID:AR
LANGUAGE_ID:AR

Обратите внимание, что я использую Java 8 forEach для доступа к элементам в массиве или списке. Возможно, вам придется изменить, если вы используете java 6 или 7

Привет, @Naveen Kumar, это работает. Спасибо, бро. Также не могли бы вы помочь мне получить значение FID «348», ТОЛЬКО если Language_ID - «AR». Я борюсь, так как на том же уровне.

Nomesh DeSilva 20.05.2018 07:49

Другие вопросы по теме