肯定有一种方法可以查询Json并使用JsonPath获取Json。请参阅下面的示例:
String jsonString = "{\"delivery_codes\": [{\"postal_code\": {\"district\": \"Ghaziabad\", \"pin\": 201001, \"pre_paid\": \"Y\", \"cash\": \"Y\", \"pickup\": \"Y\", \"repl\": \"N\", \"cod\": \"Y\", \"is_oda\": \"N\", \"sort_code\": \"GB\", \"state_code\": \"UP\"}}]}";
String jsonExp = "$.delivery_codes";
JsonNode pincodes = JsonPath.read(jsonExp, jsonString, JsonNode.class);
System.out.println("pincodesJson : "+pincodes);
上面的输出将是内部 Json。
[{“postal_code”:{“区”:“Ghaziabad”,“pin”:201001,“pre_paid”:“Y”,“cash”:“Y”,“pickup”:“Y”,“repl”:“N”,“cod”:“Y”,“is_oda”:“N”,“sort_code”:“GB”,“state_code”:“UP”}}]
现在,每个单独的名称/值对都可以通过迭代我们上面得到的列表(JsonNode)来解析。
for(int i = 0; i< pincodes.size();i++){
JsonNode node = pincodes.get(i);
String pin = JsonPath.read("$.postal_code.pin", node, String.class);
String district = JsonPath.read("$.postal_code.district", node, String.class);
System.out.println("pin :: " + pin + " district :: " + district );
}
输出将为:
pin :: 201001区 :: 加济阿巴德
根据您尝试解析的 Json,您可以决定是获取列表还是仅获取单个字符串/长整型值。
希望它有助于解决您的问题。