Java8中使用groupBy实现集合的分组,并根据某一条件进行分组

一、简介:

Java8中的groupBy实现集合的分组,类似Mysql的group by分组功能,注意得到的结果是一个map

二、代码测试案例:

package demo;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

import entity.Student;

/**
* @author :zkx
* @createtime :2020年3月17日 下午4:46:31
* @description:
*/

public class Test03 {
	
	public static void main(String[] args){
		
		List<Student> list = new ArrayList<>();
		
		Student Student1 = new Student("1", "张三", "10");
		Student Student2 = new Student("2", "张三", "11");
		Student Student3 = new Student("3", "张三", "12");
		Student Student4 = new Student("4", "李四", "13");
		Student Student5 = new Student("5", "李四", "14");
		Student Student6 = new Student("6", "李四", "15");
		Student Student7 = new Student("7", "王五", "16");
		Student Student8 = new Student("8", "王五", "17");
		Student Student9 = new Student("9", "王五", "18");
		list.add(Student1);
		list.add(Student2);
		list.add(Student3);
		list.add(Student4);
		list.add(Student5);
		list.add(Student6);
		list.add(Student7);
		list.add(Student8);
		list.add(Student9);
		
		// 根据学生的名字Name进行分组
		Map<String,List<Student>> StudentGroupMap = list.stream().
				collect(Collectors.groupingBy(Student::getName));
		
		// 分组结果
		System.out.println("分组后的数据:" + StudentGroupMap);
		System.out.println();
		
		// 循环查看分组后对应的的数据信息
		Set<String> keySet = StudentGroupMap.keySet();
		keySet.forEach((key)->{
			System.out.println(key);
			StudentGroupMap.get(key).
				forEach((Student)->
				System.out.println(Student));
		});
	}


}

三、效果图如下:

在这里插入图片描述

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Monika、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值