scala的函数式编程的分组 | GROUPBY

分组 | GROUPBY
我们如果要将数据按照分组来进行统计分析,就需要使用到分组方法
定义
groupBy表示按照函数将列表分成不同的组
方法签名
scala def groupBy[K](f: (A) ⇒ K): Map[K, List[A]]
方法解析
| groupBy方法 | API | 说明 | | ----------- | --------------- | ------------------------------------------------------------ | | 泛型 | [K] | 分组字段的类型 | | 参数 | f: (A) ⇒ K | 传入一个函数对象
接收集合元素类型的参数
返回一个K类型的key,这个key会用来进行分组,相同的key放在一组中 | | 返回值 | Map[K, List[A]] | 返回一个映射,K为分组字段,List为这个分组字段对应的一组数据 |
groupBy执行过程分析:
在这里插入图片描述
示例
有一个列表,包含了学生的姓名和性别:
scala “张三”, “男” “李四”, “女” “王五”, “男”
请按照性别进行分组,统计不同性别的学生人数
步骤
定义一个元组列表来保存学生姓名和性别
按照性别进行分组
将分组后的Map转换为列表:List((“男” -> 2), (“女” -> 1))
参考代码
<

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值