Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
 
36 / 3 / 0
Регистрация: 21.05.2018
Сообщений: 111
1

Структура JSON файла

16.08.2018, 13:22. Показов 334. Ответов 1
Метки нет (Все метки)

Здравствуйте, уважаемые форумчане! Разбираюсь с форматом JSON. И возникла такая непонятность. Создал следующий простой JSON файл:
JSON
1
2
3
4
5
6
7
8
9
10
11
12
13
{
"id1":  {"8:30":"завтрак",
        "9:00":"пробежка"},
"id2": {"9:00":"зарядка",
        "9:30":"завтрак",
        "10:00":"прогулка"},
"id3": {"9:00":"зарядка",
        "9:30":"завтрак",
        "10:00":"прогулка"},
"id4": {"9:00":"зарядка",
        "9:30":"завтрак",
        "10:00":"прогулка"}
}
Насколько я понял, сама структура файла при разборе в java представляет собой Map. То, что в фигурных скобках - и есть пары ключ - значение. Я выбираю по id значение в виде объекта (той же Map), но вылетает cast exception: Exception in thread "main" java.lang.ClassCastException: org.json.simple.JSONArray cannot be cast to org.json.simple.JSONObject. И я понимаю, что я чего-то не понимаю).
Вот код парсинга:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class JsonTest {
    static private FileReader reader;
 
    private static String getEvent(String id) throws IOException, ParseException {
        reader = new FileReader("document.json");
        JSONParser parser = new JSONParser();
        JSONObject jo = (JSONObject)parser.parse(reader);
        JSONObject events = (JSONObject) jo.get(id);
        String event = (String) events.get("9:00");
        return event;
    }
 
    public static void main(String[] args) throws IOException, ParseException {
        System.out.println(getEvent("id1"));
    }
}
Добавлено через 1 минуту
Ошибка соответственно в строке 8.

Добавлено через 2 минуты
То есть мне нужно, чтобы список событий представлял собой не List, а Map. Для решения моей задачи так проще...
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.08.2018, 13:22
Ответы с готовыми решениями:

Структура Json
Добрый день. Подскажите как сделать такую структуру json? Нужно делать массив в массиве? Не могу...

Чтение JSON-файла с помощью Newtonsoft.Json
И так, у нас есть JSon-файл вот такого типа: { "objects": { ...

Json структура из excel таблицы
Добрый день, имеется таблица с данными Исходные данные в Excel а на выходе получаем такие данные...

Ошибка при обработке Json - Cannot deserialize the current JSON array because the type requires a JSON object
Дополнительные сведения: Cannot deserialize the current JSON object (e.g. {"name":"value"}) into...

1
36 / 3 / 0
Регистрация: 21.05.2018
Сообщений: 111
17.08.2018, 12:37  [ТС] 2
Да в общем разобрался...) Оказалось, у меня в проекте 2 этих самых файла, в которых первоначально события были в [] скобках, то есть массивом. Когда я понял, что мне нужен map вместо list, я поправил, но только один из них, да и тот который не видит idea. Сегодня утром я вспомнил об этом. Вот собственно и все). А так все ОК, парсинг работает как надо.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.08.2018, 12:37

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Java, JSON и JSON Simple. Непонятка с созданием объекта JSON на сервере для отправки на фронт
Здравствуйте. Разрабатываю интернет-магазин на Java. Мне нужно на фронте получить список товаров из...

Ошибка при обработке Json - Cannot deserialize the current JSON array because the type requires a JSON object
Всем привет! Помогите, плиз, разобраться с ошибкой: An unhandled exception of type...

Структура PE файла
Доброго времени суток! Пытаюсь вручную создать исправный Exe файл, в котором PE-заголовок...

Структура файла
Добрый день, знатокам java. Имеется некий сайт представляющий свои услуги через API. Это API...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.