Разбор JSON-объекта в Java
У меня есть объект JSON следующим образом:
member = "{interests : [{interestKey:Dogs}, {interestKey:Cats}]}";
В Java я хочу проанализировать вышеупомянутый jsonobject и сохранить значения в массиве.
Может ли кто-нибудь предоставить мне фрагмент кода, с помощью которого я могу добиться этого.
Спасибо
5 ответов
Я предполагаю, что вы хотите сохранить интереса в списке.
Использование библиотеки org.json:
JSONObject obj = new JSONObject("{interests : [{interestKey:Dogs}, {interestKey:Cats}]}");
List<String> list = new ArrayList<String>();
JSONArray array = obj.getJSONArray("interests");
for(int i = 0 ; i < array.length() ; i++){
list.add(array.getJSONObject(i).getString("interestKey"));
}
public class JsonParsing {
public static Properties properties = null;
public static JSONObject jsonObject = null;
static {
properties = new Properties();
}
public static void main(String[] args) {
try {
JSONParser jsonParser = new JSONParser();
File file = new File("src/main/java/read.json");
Object object = jsonParser.parse(new FileReader(file));
jsonObject = (JSONObject) object;
parseJson(jsonObject);
} catch (Exception ex) {
ex.printStackTrace();
}
}
public static void getArray(Object object2) throws ParseException {
JSONArray jsonArr = (JSONArray) object2;
for (int k = 0; k < jsonArr.size(); k++) {
if (jsonArr.get(k) instanceof JSONObject) {
parseJson((JSONObject) jsonArr.get(k));
} else {
System.out.println(jsonArr.get(k));
}
}
}
public static void parseJson(JSONObject jsonObject) throws ParseException {
Set<Object> set = jsonObject.keySet();
Iterator<Object> iterator = set.iterator();
while (iterator.hasNext()) {
Object obj = iterator.next();
if (jsonObject.get(obj) instanceof JSONArray) {
System.out.println(obj.toString());
getArray(jsonObject.get(obj));
} else {
if (jsonObject.get(obj) instanceof JSONObject) {
parseJson((JSONObject) jsonObject.get(obj));
} else {
System.out.println(obj.toString() + "\t"
+ jsonObject.get(obj));
}
}
}
}}
Большое спасибо за код, я могу прочитать любой файл JSON благодаря вашему коду:) Теперь я пытаюсь организовать все элементы по уровням, чтобы их можно было использовать!
Я работал с Android, читая JSON по URL, и мне нужно было изменить только строки
Set<Object> set = jsonObject.keySet();
Iterator<Object> iterator = set.iterator();
за
Iterator<?> iterator = jsonObject.keys();
Я делюсь своей реализацией, чтобы помочь кому-то:
public void parseJson(JSONObject jsonObject) throws ParseException, JSONException {
Iterator<?> iterator = jsonObject.keys();
while (iterator.hasNext()) {
String obj = iterator.next().toString();
if (jsonObject.get(obj) instanceof JSONArray) {
//Toast.makeText(MainActivity.this, "Objeto: JSONArray", Toast.LENGTH_SHORT).show();
//System.out.println(obj.toString());
TextView txtView = new TextView(this);
txtView.setText(obj.toString());
layoutIzq.addView(txtView);
getArray(jsonObject.get(obj));
} else {
if (jsonObject.get(obj) instanceof JSONObject) {
//Toast.makeText(MainActivity.this, "Objeto: JSONObject", Toast.LENGTH_SHORT).show();
parseJson((JSONObject) jsonObject.get(obj));
} else {
//Toast.makeText(MainActivity.this, "Objeto: Value", Toast.LENGTH_SHORT).show();
//System.out.println(obj.toString() + "\t"+ jsonObject.get(obj));
TextView txtView = new TextView(this);
txtView.setText(obj.toString() + "\t"+ jsonObject.get(obj));
layoutIzq.addView(txtView);
}
}
}
}
1.) Создайте массив данных соответствующего типа, в данном случае, т.е. String
2.) Создать JSONObject
передавая вашу строку JSONObject
конструктор как вход
- Как
JSONObject
нотация представлена фигурными скобками, т.е.{}
- В то время как
JSONArray
запись представлена квадратными скобками, т.е.[]
3.) Получить JSONArray
от JSONObject
(создается на 2-м шаге) с помощью "interests"
в качестве индекса.
4.) Траверс JASONArray
используя циклы до длины массива, предоставленной length()
функция
5.) Получите ваш JSONObjects
от JSONArray
с помощью getJSONObject(index)
функция
6.) Получить данные из JSONObject
используя индекс "InterestKey".
Замечания: JSON
синтаксический анализ использует escape-последовательность для специальных вложенных символов, если ответ json (обычно из других API-интерфейсов ответа JSON) содержит кавычки ("
) как это
`"{"key":"value"}"`
должно быть так
`"{\"key\":\"value\"}"`
так что вы можете использовать JSONParser
добиться экранированного формата последовательности для безопасности, как
JSONParser parser = new JSONParser();
JSONObject json = (JSONObject) parser.parse(inputString);
Код:
JSONParser parser = new JSONParser();
String response = "{interests : [{interestKey:Dogs}, {interestKey:Cats}]}";
JSONObject jsonObj = (JSONObject) parser.parse(response);
или же
JSONObject jsonObj = new JSONObject("{interests : [{interestKey:Dogs}, {interestKey:Cats}]}");
List<String> interestList = new ArrayList<String>();
JSONArray jsonArray = jsonObj.getJSONArray("interests");
for(int i = 0 ; i < jsonArray.length() ; i++){
interestList.add(jsonArray.getJSONObject(i).optString("interestKey"));
}
Примечание: иногда вы можете увидеть некоторые исключения, когда values are not available in appropriate type or is there is no mapping key
так что в тех случаях, когда вы не уверены в наличии значения, используйте optString
, optInt
, optBoolean
и т.д., который просто вернет значение по умолчанию, если оно отсутствует, и даже попытается преобразовать значение в int, если оно имеет строковый тип, и наоборот, поэтому просто нет исключений null или NumberFormat вообще в случае отсутствия ключа или значения
Получить необязательную строку, связанную с ключом. Возвращает defaultValue, если такого ключа нет.
public String optString(String key, String defaultValue) {
String missingKeyValue = json_data.optString("status","N/A");
// note there is no such key as "status" in response
// will return "N/A" if no key found
или получить пустую строку т.е. ""
если ключ не найден, просто используйте
String missingKeyValue = json_data.optString("status");
// will return "" if no key found where "" is an empty string
Дальнейшая ссылка на исследование
В Java доступно много библиотек JSON.
Наиболее известные из них: Джексон, GSON, Genson, FastJson и org.json.
Как правило, есть три вещи, на которые следует обратить внимание при выборе любой библиотеки:
- Спектакль
- Простота использования (код прост для написания и разборчивый) - это идет с функциями.
- Для мобильных приложений: размер зависимости / размер фляги
В частности, для библиотек JSON (и любых библиотек сериализации / десериализации) связывание данных также обычно представляет интерес, поскольку устраняет необходимость написания стандартного кода для упаковки / распаковки данных.
Для 1, см. Этот тест: https://github.com/fabienrenaud/java-json-benchmark Я сделал с помощью JMH, который сравнивает (Джексон, GSON, GENSON, FastJSON, ORG.JSON, JSONP) производительность сериализаторов и десериализаторов с использованием потока и API привязки данных. Для 2 вы можете найти множество примеров в Интернете. Вышеприведенный тест также можно использовать в качестве источника примеров...
Быстрый тест: Джексон работает в 5-6 раз лучше, чем org.json, и более чем в два раза лучше, чем GSON.
Для вашего конкретного примера следующий код декодирует ваш JSON с Джексоном:
public class MyObj {
private List<Interest> interests;
static final class Interest {
private String interestKey;
}
private static final ObjectMapper MAPPER = new ObjectMapper();
public static void main(String[] args) throws IOException {
MyObj o = JACKSON.readValue("{\"interests\": [{\"interestKey\": \"Dogs\"}, {\"interestKey\": \"Cats\" }]}", MyObj.class);
}
}
Дайте знать, если у вас появятся вопросы.