Преобразовать список в многомерную карту - PullRequest
3 голосов
/ 16 апреля 2019

Я хотел бы преобразовать (с Java8 ) список данных (JSON) в иерархическую структуру.

Не могли бы вы сказать, как лучше всего обращаться сthis?

Как я могу преобразовать arraylist в многомерную карту ?

Проблема в чем-то вроде преобразования этого:

{
"server": "Manufacturer Co.",
"vehicles": [
    {
        "year": 2018,
        "model": "Ford Explorer (1)",
        "category": "4WD"
    },
    {
        "year": 2018,
        "model": "Ford Explorer (2)",
        "category": "4WD"
    },
    {
        "year": 2017,
        "model": "Ford Mustang (3)",
        "category": "2WD"
    }
    {
        "year": 2017,
        "model": "Ford Mustang 4WD (4)",
        "category": "4WD"
    }
}

в это

vehicles
-- year 2018
----- category: 4WD
---------- Ford Explorer (1)
---------- Ford Explorer (2)
-- year 2017
----- category: 2WD
---------- Ford Mustang (3)
----- category: 4WD
---------- Ford Mustang (4)

Спасибо за ваше время

Ответы [ 2 ]

4 голосов
/ 16 апреля 2019

Вы должны использовать несколько groupingBy, а затем mapping, чтобы собрать свойство модели в список.

Я предполагал, что у вас есть модель примерно такая:

public class Vehicle {
    private int year;
    private String model;
    private String category;

    //other 
}


Map<Integer,Map<String,List<String>>> result =  vehicles.stream()
            .collect(Collectors.groupingBy(Vehicle::getYear,
                    Collectors.groupingBy(Vehicle::getCategory, 
                            Collectors.mapping(Vehicle::getModel, Collectors.toList()))));
2 голосов
/ 16 апреля 2019

Есть два подхода.Сначала нужно создать Map с ключом Year из Map с, с ключом Category из Model с.Переберите все транспортные средства, создайте запись на год, если она не существует, добавьте категорию, если она не существует, и добавьте модель, если она не существует.

Немного более элегантный подходбыть использовать базу данных в памяти.Создайте таблицу vehicles со столбцами year, category и model, а затем запросите ее с помощью:

select year, category, model
from   vehicle
order by year, category;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...