[英]How to add increment values using a hashmap of <Integer,HashMap<Integer,Integer>
我有一个名为 client 的表,其中有一个名为 created_time 的列,所以实际上我想 plot 一个 map,这样我就可以知道在哪一年和哪一个月添加了多少客户? 现在的问题是假设在 2018 年 11 月添加了 2 个客户,在 2018 年 12 月添加了 0 个客户,所以在 12 月我也会显示 2 个(就像上面的月份 + 当前月份),如果在 2019 年 1 月添加了 1 个客户,那么我会展示 3 等等
所以为了解决这个问题,我创建了一个 hashMap,其中第一个键是年,我创建了另一个 hashMap,其中键是月,然后是添加的客户端编号,例如 HashMap>
预期 Output::
clientsByMonth": {
"2018": {
"10": 1,(1 client added in oct)
11,1( as 0 client added in nov)
12,2( as 1 client added in december)
},
"2019": {
"1": 2, ( as no client added )
"2": 4, (as 2 client added)
"3": 5,
"4": 5
}
HashMap<Integer, HashMap<Integer, Integer>> clientsByYear = new HashMap<>();
List<Client> clientList = clientRepository.findAll();
for (int i = 0; i < clientList.size(); i++) {
Instant instant = Instant.ofEpochMilli(clientList.get(i).getCreatedTime().getTime());
LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, ZoneId.systemDefault());
Integer month = localDateTime.toLocalDate().getMonth().getValue();
Integer year = localDateTime.toLocalDate().getYear();
if (!clientsByYear.containsKey(year)) {
HashMap<Integer, Integer> clientByMonth = new HashMap<>();
clientByMonth.put(month, 1);
clientsByYear.put(year, clientByMonth);
} else {
HashMap<Integer, Integer> clientByMonth = clientsByYear.get(year);
if (!clientByMonth.containsKey(month)) {
int clients = 0;
for (int j = month - 1; j >= 0; j--) {
if (clientByMonth.containsKey(j)) {
clients = clients + clientByMonth.get(j);
break;
}
}
clientByMonth.put(month, (clients + 1));
} else if (clientByMonth.containsKey(month)) {
int clients = clientByMonth.get(month);
clientByMonth.put(month, (clients + 1));
}
}
}
见下文,如果我正确理解您的问题,它应该可以解决您的问题
for (int i = 1; i <=clientList.size() ; i++) {
...
if (!clientsByYear.containsKey(year)) {
HashMap<Integer, Integer> clientByMonth = new HashMap<>();
clientByMonth.put(month, i);
clientsByYear.put(year, clientByMonth);
} else {
HashMap<Integer, Integer> clientByMonth = clientsByYear.get(year);
clientByMonth.put(month, i);
}
}
System.out.println(clientsByYear);
}
预期:输入数据按时间 asc 排序
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.