java的List流操作

目录

一、groupingBy

1、groupingBy介绍

2、groupingBy使用


一、groupingBy

1、groupingBy介绍

roupingBy()是Stream API中最强大的收集器Collector之一,提供与SQL的GROUP BY子句类似的功能。

2、groupingBy使用

1、对整个字段进行分组查询:直接groupingBy那个字段就可以了

2、对字段的一部分进行分组查询:s->s.getId().substring(0, 3),获取到这个字段后进行字符串截取。

3、对每个分组的数据个数进行统计:Collectors.groupingBy(UserEntity::getId,Collectors.counting())

4、对id字段进行分组并获取age的平均数:

Collectors.groupingBy(UserEntity::getId,Collectors.averagingInt(UserEntity::getAge)) 

5、对id字段进行分组并获取age的总值:

Collectors.groupingBy(UserEntity::getId, Collectors.summingInt(UserEntity::getAge))

public class Stream {

    public static void main(String[] args) {

        groupById(); // 对id字段进行分组查询
        groupByPartId(); // 对id字段的部分进行分组查询
        groupByIdGetCount(); // 对每个分组的数据个数进行统计
        groupByIdGetAgeAve(); // 对id字段进行分组并获取age的平均数
        groupByIdGetAgeSum(); // 对id字段进行分组并获取age的总值

    }

    public static void groupById(){
        UserEntity user1 = new UserEntity("1001", "zhangsan", 18, "123");
        UserEntity user2 = new UserEntity("1001", "lisi", 20, "123");
        UserEntity user3 = new UserEntity("1001", "wangwu", 15, "123");
        UserEntity user4 = new UserEntity("2001", "张三", 22, "123");
        UserEntity user5 = new UserEntity("2001", "李四", 21, "123");
        UserEntity user6 = new UserEntity("2001", "王五",23, "123");
        List<UserEntity> list = new ArrayList<>();
        list.add(user1);
        list.add(user2);
        list.add(user3);
        list.add(user4);
        list.add(user5);
        list.add(user6);
        Map<String, List<UserEntity>> map = list.stream().collect(Collectors.groupingBy(UserEntity::getId));
        map.forEach((key, value)->{
            System.out.println(key+":"+value);
            /*
            1001:[UserEntity(id=1001, name=zhangsan, age=18, password=123), UserEntity(id=1001, name=lisi, age=20, password=123), UserEntity(id=1001, name=wangwu, age=15, password=123)]
            2001:[UserEntity(id=2001, name=张三, age=22, password=123), UserEntity(id=2001, name=李四, age=21, password=123), UserEntity(id=2001, name=王五, age=23, password=123)]
             */
        });
    }
    public static void groupByPartId(){
        UserEntity user1 = new UserEntity("1001", "zhangsan", 19, "123");
        UserEntity user2 = new UserEntity("1002", "lisi", 17, "123");
        UserEntity user3 = new UserEntity("1003", "wangwu", 18, "123");
        UserEntity user4 = new UserEntity("2001", "张三", 28, "123");
        UserEntity user5 = new UserEntity("2002", "李四", 23, "123");
        UserEntity user6 = new UserEntity("2003", "王五", 26, "123");

        List<UserEntity> list = new ArrayList<>();
        list.add(user1);
        list.add(user2);
        list.add(user3);
        list.add(user4);
        list.add(user5);
        list.add(user6);
        Map<String, List<UserEntity>> map = list.stream().collect(Collectors.groupingBy(s->s.getId().substring(0, 3)));
        map.forEach((key, value)->{
            System.out.println(key+":"+value);
            /*
            100:[UserEntity(id=1001, name=zhangsan, age=19, password=123), UserEntity(id=1002, name=lisi, age=17, password=123), UserEntity(id=1003, name=wangwu, age=18, password=123)]
            200:[UserEntity(id=2001, name=张三, age=28, password=123), UserEntity(id=2002, name=李四, age=23, password=123), UserEntity(id=2003, name=王五, age=26, password=123)]
             */
        });
    }

    private static void groupByIdGetCount() {
        UserEntity user1 = new UserEntity("1001", "zhangsan", 18, "123");
        UserEntity user2 = new UserEntity("1001", "lisi", 20, "123");
        UserEntity user3 = new UserEntity("1001", "wangwu", 15, "123");
        UserEntity user4 = new UserEntity("2001", "张三", 22, "123");
        UserEntity user5 = new UserEntity("2001", "李四", 21, "123");
        UserEntity user6 = new UserEntity("2001", "王五",23, "123");
        List<UserEntity> list = new ArrayList<>();
        list.add(user1);
        list.add(user2);
        list.add(user3);
        list.add(user4);
        list.add(user5);
        list.add(user6);
        Map<String, Long> map = list.stream().collect(Collectors.groupingBy(UserEntity::getId, Collectors.counting()));
        map.forEach((key, value)->{
            System.out.println(key+":"+value);
            /*
            1001:3
            2001:3
             */
        });
    }

    private static void groupByIdGetAgeAve() {

        UserEntity user1 = new UserEntity("1001", "zhangsan", 18, "123");
        UserEntity user2 = new UserEntity("1001", "lisi", 20, "123");
        UserEntity user3 = new UserEntity("1001", "wangwu", 15, "123");
        UserEntity user4 = new UserEntity("2001", "张三", 22, "123");
        UserEntity user5 = new UserEntity("2001", "李四", 21, "123");
        UserEntity user6 = new UserEntity("2001", "王五",23, "123");
        List<UserEntity> list = new ArrayList<>();
        list.add(user1);
        list.add(user2);
        list.add(user3);
        list.add(user4);
        list.add(user5);
        list.add(user6);
        Map<String, Double> map = list.stream().collect(Collectors.groupingBy(UserEntity::getId,
                Collectors.averagingInt(UserEntity::getAge)));
        map.forEach((key, value)->{
            BigDecimal bigDecimal = new BigDecimal(value);
            bigDecimal.setScale(2, BigDecimal.ROUND_HALF_UP);
            System.out.println(key+":"+value); // 要想保留两位小数 使用bigDecimal, 四舍五入
            /*
            1001:17.666666666666668
            2001:22.0
             */
        });
    }

    private static void groupByIdGetAgeSum() {
        UserEntity user1 = new UserEntity("1001", "zhangsan", 18, "123");
        UserEntity user2 = new UserEntity("1001", "lisi", 20, "123");
        UserEntity user3 = new UserEntity("1001", "wangwu", 15, "123");
        UserEntity user4 = new UserEntity("2001", "张三", 22, "123");
        UserEntity user5 = new UserEntity("2001", "李四", 21, "123");
        UserEntity user6 = new UserEntity("2001", "王五",23, "123");
        List<UserEntity> list = new ArrayList<>();
        list.add(user1);
        list.add(user2);
        list.add(user3);
        list.add(user4);
        list.add(user5);
        list.add(user6);
        Map<String, Integer> map = list.stream().collect(Collectors.groupingBy(UserEntity::getId,
                Collectors.summingInt(UserEntity::getAge)));
        map.forEach((key, value)->{
            System.out.println(key+":"+value); // 要想保留两位小数 使用bigDecimal, 四舍五入
            /*
            1001:53
            2001:66
             */
        });
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值