Ответ JSON Parse может иметь один или несколько объектов
Вопрос
Мне нужно разобрать этот ответ на Android, используя анализатор Android JSON, но то, что я не могу найти ответ в любом месте:
Как связать данные, если например, «маршруты» могут содержать один или иногда больше объектов маршрута типа? Если он содержит одно, чем он возвращается, но если он содержит больше, он возвращается с [] с этим примером «Маршрут» не может быть помещен в JSONARRAY, потому что это не массив. (не помещен в [] правильно?)
Как мне это разбирать? Любые примеры?
{
"plan":{
"date":"2010-10-20T00:00:00+02:00",
"from":{
"name":"Булевар Партизански Одреди",
"stopId":"123",
"lon":"21.373255285035548",
"lat":"42.00736515785779",
"geometry":"{\"type\": \"Point\", \"coordinates\": [21.373255285035548,42.00736515785779]}"
},
"to":{
"name":"Булевар Партизански Одреди",
"stopId":"123",
"lon":"21.37228809181389",
"lat":"42.00762790595865",
"geometry":"{\"type\": \"Point\", \"coordinates\": [21.37228809181389,42.00762790595865]}"
},
"itineraries":{
"itinerary":{
"duration":"159000",
"startTime":"2010-10-20T00:00:00+02:00",
"endTime":"2010-10-20T00:02:39+02:00",
"walkTime":"159000",
"transitTime":"0",
"waitingTime":"0",
"walkDistance":"212.6496008849819",
"elevationLost":"0.0",
"elevationGained":"0.0",
"transfers":"0",
"legs":{
"leg":{
"@route":"Булевар Партизански Одреди",
"@mode":"WALK",
"startTime":"2010-10-20T00:00:00+02:00",
"endTime":"2010-10-20T00:02:39+02:00",
"distance":"212.6496008849819",
"from":{
"name":"Булевар Партизански Одреди",
"lon":"21.373255285035548",
"lat":"42.00736515785779",
"geometry":"{\"type\": \"Point\", \"coordinates\": [21.373255285035548,42.00736515785779]}"
},
"to":{
"name":"Булевар Партизански Одреди",
"lon":"21.37228809181389",
"lat":"42.00762790595865",
"geometry":"{\"type\": \"Point\", \"coordinates\": [21.37228809181389,42.00762790595865]}"
},
"legGeometry":{
"length":"3",
"points":"_qk_GymmaCf@qC{ArI"
},
"steps":{
"walkSteps":{
"distance":"212.6496008849819",
"streetName":"Булевар Партизански Одреди",
"absoluteDirection":"EAST",
"stayOn":"false",
"becomes":"false",
"lon":"21.373255285035548",
"lat":"42.00736515785779",
"elevation":""
}
},
"duration":"159000"
}
},
"tooSloped":"false"
}
}
},
"requestParameters":{
"entry":[
{
"key":"optimize",
"value":"QUICK"
},
{
"key":"time",
"value":"9:40 am\""
},
{
"key":"wheelchair",
"value":"false"
},
{
"key":"maxWalkDistance",
"value":"800.0"
},
{
"key":"fromPlace",
"value":"42.0074711701039,21.3732840843651"
},
{
"key":"toPlace",
"value":"42.0076745404488,21.3723007605583"
},
{
"key":"date",
"value":"10/20/2010"
},
{
"key":"mode",
"value":"TraverseMode (WALK, TRAM, SUBWAY, RAIL, BUS, FERRY, CABLE_CAR, GONDOLA, FUNICULAR, TRANSIT, TRAINISH, BUSISH)"
},
{
"key":"numItineraries",
"value":"3"
}
]
}
}
Вот что я использую для первой части
JSONObject planObject=json.getJSONObject("plan");
Log.i("date",planObject.get("date").toString());
JSONObject fromObject=planObject.getJSONObject("from");
Log.i("from object",fromObject.get("name").toString());
Log.i("from object",fromObject.get("stopId").toString());
Log.i("from object",fromObject.get("lon").toString());
Log.i("from object",fromObject.get("lat").toString());
Это пример Феликс написал, и оно о нескольких «маршрутах»
"itineraries": [
{"duration": "123456", ... },
{"duration": "789012", ... }
]
Это будет тот же пример, но для одного:
"itineraries":
{"duration": "123456", ... },
Таким образом, во втором случае Jsonarray не так, если я стараюсь использовать код FELIX, данный для анализа массива, он вернет ошибку.
Таким образом, вопрос в том, что такое способ проверить, может ли значение можно поместить в JSONARRAY. Является ли команда Optjsonarray («PossiblearRayValues»)! = Используется NULL или есть лучший метод, то делая много, если я проверяет?
Решение
Я не думаю, что это юридический иметь несколько клавиш с тем же именем в объекте JSON. Т.е. ключевые ключи в объекте JSON должны образовывать набор, не список.
Можете ли вы разместить пример, когда есть больше маршрутов? Могу поспорить, что это будет выглядеть что-то вроде:
...
"itineraries": [
{"duration": "123456", ... },
{"duration": "789012", ... }
]
...
Если это делает Похоже, разборки это легко:
JSONArray itineraries = planObject.getJSONArray("itineraries");
for (int i=0; i < itineraries.length(); i++) {
Log.i("TAG", itineraries.getJSONObject(i).getString("duration");
}
Если это нет, API, с которым вы работаете, сломана. Либо исправьте это или скажу, кто забегает его, чтобы исправить это :)
Редактировать: Теперь, когда мы знаем, как выглядит ответ с несколькими элементами, вот как разбирать его:
Object itineraries = planObject.get("itineraries");
if (itineraries instanceof JSONObject) {
JSONObject itinerary = (JSONObject) itineraries;
// right now, itinerary is your single item
}
else {
JSONArray array = (JSONArray) itineraries;
// do whatever you want with the array of itineraries
}
Непроверенный, но он должен работать.