可以实现对嵌套list的操作(将多维嵌套列表转换为单维列表)
上例子:
[
{
"groupCode": "221",
"groupName": "测试组一"
"groupType": 1
"taskList": [
{
"taskCode": "221",
"taskName": "任务一",
"taskType": "1",
"sequence": 1
},
{
"taskCode": "222",
"taskName": "任务二",
"taskType": "1",
"sequence": 1
},
]
},
{
"groupCode": "222",
"groupName": "测试组二"
"groupType": 1
"taskList": [
{
"taskCode": "333",
"taskName": "任务三",
"taskType": "1",
"sequence": 1
},
{
"taskCode": "444",
"taskName": "任务四",
"taskType": "1",
"sequence": 1
},
]
}
]
这个是个json对象,一个list数组,里面对象中还有一个list数组taskList(嵌套list)
那么我们怎么统计出所有的groupCode的值呢?
假设我的对象是
List<GroupDetailDTO> groupList;
其中GroupDetailDTO有一个属性:
private List<TaskDetailDTO> taskList;
List<String> groupCodes = groupList.stream().map(GroupDetailDTO::getGroupCode).distinct().collect(Collectors.toList());
这样就可以了;
上面这个是map的用法;
那我们怎么统计数据中所有的taskCode的值呢?
就需要用到flatMap了:
List<String> taskCodes = groupList.stream().flatMap(groupDetailDTO -> groupDetailDTO .getTaskList().stream()).map(TaskDetailDTO::getTaskCode).distinct().collect(Collectors.toList());
怎么理解呢?这里其实可以看成两部分,
首先用flatMap把所有的taskList汇聚到一起,然后再用map提取taskCode的值;
总结:
一对多的提取内容用flatmap,一对一用map
天下文章一大抄,就看你抄了后明不明白:
https://didispace-wx.blog.csdn.net/article/details/103331551