Я пытался отлаживать эту проблему часами и имею в виду Google и не могу найти кого-то, у кого такая же проблема. По какой-то причине JSONObject/JSONTokener делает причудливые вещи.Почему JSONTokener/Object продолжает рандомизировать мои данные json?
Следующий код:
JSONObject jsonObj = (JSONObject) new JSONTokener(sourceJson).nextValue();
Log.d(" ", sourceJson + "\n");
Log.d(" ", jsonObj.toString());
Производит этот вывод:
{
"2012":{
"federal":[[10822,0.15],[42707,0.22],[85414,0.26],[132406,0.29]],
"provincial":{
"AB":[[17282,0.1]],
"BC":[[11354,0.0506],[37013,0.077],[74028,0.105],[84993,0.1229],[103205,0.147]],
"MB":[[8634,0.108],[31000,0.1275],[67000,0.174]],
"NB":[[9203,0.091],[38190,0.121],[76380,0.124],[124178,0.143]],
"NL":[[8237,0.077],[32893,0.125],[65785,0.133]],
"NS":[[8481,0.0879],[29590,0.1495],[59180,0.1667],[93000,0.175],[150000,0.21]],
"NT":[[13280,0.059],[38679,0.086],[77360,0.122],[125771,0.1405]],
"NU":[[12211,0.04],[40721,0.07],[81442,0.09],[132406,0.115]],
"ON":[[9405,0.0505],[39020,0.0915],[78043,0.1116],[500000,0.1216]],
"PE":[[7708,0.098],[31984,0.138],[63969,0.167]],
"QC":[[10925,0.16],[40100,0.2],[80200,0.24]],
"SK":[[14942,0.11],[42065,0.13],[120185,0.15]],
"YT":[[10822,0.0704],[42707,0.0968],[85414,0.1144],[132406,0.1276]]
}
}
}
{"2012":{"provincial":{"ON":[[9405,0.0505],[39020,0.0915],[78043,0.1116],[500000,0.1216]],"AB":[[17282,0.1]],"BC":[[11354,0.0506],[37013,0.077],[74028,0.105],[84993,0.1229],[103205,0.147]],"NL":[[8237,0.077],[32893,0.125],[65785,0.133]],"QC":[[10925,0.16],[40100,0.2],[80200,0.24]],"NU":[[12211,0.04],[40721,0.07],[81442,0.09],[132406,0.115]],"SK":[[14942,0.11],[42065,0.13],[120185,0.15]],"PE":[[7708,0.098],[31984,0.138],[63969,0.167]],"NT":[[13280,0.059],[38679,0.086],[77360,0.122],[125771,0.1405]],"NS":[[8481,0.0879],[29590,0.1495],[59180,0.1667],[93000,0.175],[150000,0.21]],"YT":[[10822,0.0704],[42707,0.0968],[85414,0.1144],[132406,0.1276]],"NB":[[9203,0.091],[38190,0.121],[76380,0.124],[124178,0.143]],"MB":[[8634,0.108],[31000,0.1275],[67000,0.174]]},"federal":[[10822,0.15],[42707,0.22],[85414,0.26],[132406,0.29]]}}
Красиво отформатированные данные выше идентичен файлу data.json, который я использовал для заполнения sourceJson
и очень длинной линии имел порядок провинций, таинственно перестроенных (но не данных в 2D-массив каждой провинции).
Я также попытался:
JSONObject jsonObj = new JSONObject(sourceJson); // same problem
и
JSONTokener jsonTk = new JSONTokener(sourceJson);
Log.d(" ", jsonTk.toString()); // result = " at character 0 of " + sourceJson;
Log.d(" ", jsonTk.nextValue().toString()); // output same as original problem
Я также попытался с помощью контрольной точки, чтобы отследить вызов nextValue()
, но не смог найти причину проблемы. Поведение предполагает, что конструктор JSONObject (String) может вызывать nextValue(), поскольку оба метода дают один и тот же результат.
Вопрос в следующем: Кто-нибудь знает, почему JSONObject/JSONTokener.nextValue() ведет себя таким образом? И что еще более важно, знаете ли вы, как заставить его анализировать данные JSON без его реорганизации? (Мне нужно перебирать данные, даже если файл данных будет изменяться в будущем)
Спасибо, связка!
Спасибо! Теперь это имеет больше смысла. Понимая, что я не могу сделать это так, как я предполагал, заставил меня придумать лучшее решение за считанные минуты (смешно, как все работает, иногда), так что, спасибо! :) – Nalorin