Scala(五)【集合的高级使用】
- 一.集合属性
- 二.集合方法
- drop、dropRight
- distinct:去重
- head、last:获取第一个、最后一个元素
- tail、init:去除第一个元素剩余的所有元素、去除最后一个元素剩余的所有元素、
- isEmpty:是否为空
- intersect、diff、union:交集、差集、并集
- max、min:最大、最小值
- sum:求和
- reverse:反转
- sliding(窗口长度,滑动步长)
- tail:除开最后一个元素,返回剩余元素组成的集合
- take(n):获取前多少个元素,TopN
- 求集合交集、并集、差集:intersect,diff,union
- zip:拉链
- unzip:反拉链
- sorted:升序
- sortBy:指定排序条件
- sortWith:自定义升降序
- 三.集合的高级函数(重要)
一.集合属性
size
获取集合的大小
list.size
length
获取集合的长度
list.length
contains
是否包含
val list = List[Int](3,7,2,9,10)
list.contains(100
mkString
转字符串,参数是元素的分隔符。
val list = List(1, 2, 3, 4)
println(list.mkString("-"))//结果:1-2-3-4
二.集合方法
drop、dropRight
删除前[后]多少个元素,保留剩下的元素
val list1 = list.drop(3)
val list2 = list.dropRight(3)
distinct:去重
head、last:获取第一个、最后一个元素
tail、init:去除第一个元素剩余的所有元素、去除最后一个元素剩余的所有元素、
isEmpty:是否为空
intersect、diff、union:交集、差集、并集
max、min:最大、最小值
sum:求和
reverse:反转
sliding(窗口长度,滑动步长)
tail:除开最后一个元素,返回剩余元素组成的集合
take(n):获取前多少个元素,TopN
求集合交集、并集、差集:intersect,diff,union
zip:拉链
val list14 = List[String]("name","age","address","sex","aa")
val list15 = List[Any]("zhangsan",20,"shenzhen","男")
val list16 = list14.zip(list15)
println(list16)// List((name,zhangsan), (age,20), (address,shenzhen), (sex,男))
unzip:反拉链
返回一个二元元祖,2个List
//list16:((name,zhangsan), (age,20), (address,shenzhen), (sex,男))
val list17 = list16.unzip
println(list17)//(List(name, age, address, sex),List(zhangsan, 20, shenzhen, 男))
sorted:升序
//排序,升序
val list1 = list.sorted
//降序
val list2 = list.sorted.reverse
sortBy:指定排序条件
默认升序
val list3 = List[(String,Int)]( ("zhangsan",20),("lisi",30),("wangwu",15),("zhaoliu",5) )
val list = list3.sortBy(_._1)
sortWith:自定义升降序
// 函数体中< 代表是升序 >代表是降序
val list5 = list3.sortWith((x,y)=>x._2<y._2)
//升序
val list7 = list3.sortWith(_._2<_._2)
println(list7)//List((zhaoliu,5), (wangwu,15), (zhangsan,20), (lisi,30))
//降序
val list6 = list3.sortWith((x,y)=>x._2>y._2)
println(list6)//List((lisi,30), (zhangsan,20), (wangwu,15), (zhaoliu,5))
三.集合的高级函数(重要)
map:转换(一对一)
对list每个元素都执行一次,返回一个新的list
val list8 = List[String]("hello","word","python","hadoop")
val list9 = list8.map(x=>x.length)//List(5, 4, 6, 6)
class Person(val name:String,val age:Int)
val list10 = List[(String,Int)]( ("zhangsan",20),("lisi",50),("wangwu",60))
val list11 = list10.map(x=> new Person(x._1,x._2))//List(对象一,对象二,对象三)
flatten:压平(一对多)
只压第二层
val list12 = List[List[String]] ( List("scala","python"),List("hadoop","flume","kafka") )
val list13 = list12.flatten////List("scala","python","hadoop","flume","kafka")
//string也属于Seq,可以被压平成字符
val list16 = List[String]("hello spark","hello scala")
val list17 = list16.flatten
println(list17) //List(h, e, l, l, o, , s, p, a, r, k, h, e, l, l, o, , s, c, a, l, a)
flatMap:转换+压平(一对多)
等价于先map,再flatten
val list16 = List[String]("hello python","hello scala","hadoop flume")
val list17 = list16.map(x=>x.split(" ")).flatten
println(list17)//List(hello, spark, hello, scala)
groupBy:(多对一)
根据自定义的规则进行分组,分组后的结果是一个Map,key是分组的条件,value是一个List
val list = List(("Shenczhen", "zhagnsan", 20), ("guangzhou", "lisi", 10), ("Shenczhen", "wangwu", 30), ("Shenczhen", "zhaoliu", 20), ("chengdu", "wuqi", 10))
val map: Map[(String, Int), List[(String, String, Int)]] = list.groupBy(x => {
(x._1, x._3)
})
println(map) //Map((Shenczhen,30) -> List((Shenczhen,wangwu,30)),
//(chengdu,10) -> List((chengdu,wuqi,10)),
// (guangzhou,10) -> List((guangzhou,lisi,10)),...)
reduce:聚合(多对一)
迭代计算,本次计算的结果作为下次计算的输出
sum默认给的是集合的第一个值,然后从第二个元素开始遍历
从左往右
val list1 = List(1, 2, 3, 4)
val s = list1.reduce((sum, x)=>sum+x)
println(s)
flod(初始值)(函数):叠加(多对一)
从左往右
sum默认给的是集合的第一个括号参数的值,然后从第一个元素开始遍历
val i = list1.fold(0)((sum,x)=>sum+x)
println(i)
println(i)
filter
过滤,判断条件为True保留,返回过滤后的List集合
//找出集合中的偶数
val list1 = List(1, 2, 3, 4, 5)
val listfilter =list1.filter(x => {
x % 2 == 0
})
println(listfilter)//List(2, 4)
Scala(五)【集合的高级使用】的更多相关文章
- Scala进阶之路-高级数据类型之集合的使用
Scala进阶之路-高级数据类型之集合的使用 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Scala 的集合有三大类:序列 Seq.集 Set.映射 Map,所有的集合都扩展自 ...
- C#可扩展编程之MEF学习笔记(五):MEF高级进阶
好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...
- Scala进阶之路-高级数据类型之数组的使用
Scala进阶之路-高级数据类型之数组的使用 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数组的初始化方式 1>.长度不可变数组Array 注意:顾名思义,长度不可变数 ...
- Scala:集合类型Collection和迭代器
http://blog.csdn.net/pipisorry/article/details/52902549 Scala Collection Scala 集合分为可变的和不可变的集合. 可变集合可 ...
- Scala数组| 集合
arrays :+ 5尾部 头部5 +: arrays TODO 声明不可变数组,不能删; 默认情况下,scala中集合的声明全都是不可变的 val arrays: Array[Int] = Ar ...
- scala 可变集合与内存清理的关系
留坑待填 使用scala.collection.mutable._期间,发现了当程序运行内存开销较多时,使用系统工具进行内存清理,然后程序报出了变量找不到.内存无法访问.数组访问越界,堆栈溢出等多种错 ...
- Scala学习——集合的使用和“_”的一些使用(中)
1.空格加_可以表示函数的原型 命令行代码: scala> def fun1(name:String){println(name)} fun1: (name: String)Unit scala ...
- scala集合和高级函数操作
scala常用函数操作 reduceLeft 是将集合的元素从左向右进行所需要的相应操作,图以减法为例展示,表达的算法是 : 1-2-3-4-5 例: (1 to 5).reduceLeft(_ ...
- [转] Scala 的集合类型与数组操作
[From] https://blog.csdn.net/gongxifacai_believe/article/details/81916659 版权声明:本文为博主原创文章,转载请注明出处. ht ...
随机推荐
- 聊了聊宏内核和微内核,并吹了一波 Linux
看这里!!!https://mp.weixin.qq.com/s?__biz=MzI0ODk2NDIyMQ==&mid=2247494048&idx=1&sn=cacfc6a4 ...
- Win10下C语言转8086汇编
目录 Win10下C语言转8086汇编 简介 开始 写C代码 转换成汇编代码 Win10下C语言转8086汇编 简介 最近学习<王爽汇编>,然后突发奇想,想一边写C语言用编译器将其翻译成汇 ...
- Burp Suite Pro 2021.10 Full (macOS, Linux) -- 查找、发现和利用漏洞
申明:底层组件来自网络论坛或开源社区的分享,本站所有软件免费分享,仅供学习和测试使用,严禁用于任何商业用途!!! 请访问原文链接:https://sysin.cn/blog/burp-suite-pr ...
- 区块链开发学习第三章:私有链上部署helloBlockchain简单合约
前面讲了部署私有链以及新增账户,现在进行到了部署合约了,此操作真是踩了无数无数无数的坑,到写文章为止确实是已经部署好了,但是还有些坑是还没有解决的! 一.Solidity编译器 开始的时候用的http ...
- APP自动化之Hybrid自动化解决方案(七)
基于UIAutomator+ChromeDriver模式(UIAutomator安卓原生引擎) 原理:native(原生)部分使用UIAutomator,webview部分使用ChromeDriver ...
- Swift-Framework(一)访问资源文件
摘要 Framework 就是在 APP 应用中的一种封装功能的表现形式,虽然不能独立运行,但是也可以在它里面存放和访问图片.语音等资源文件,可算是麻雀虽小,五脏俱全. 毕竟不是 APP 工程,所以 ...
- Jenkins执行 remote SSH 命令
1.安装 SSH Pipeline Steps 插件 2.在凭据中添加remote server凭据,如下 3.Pipeline编写: def GetRemoteServer(ip){ def rem ...
- linux查看和修改时间
查看时间: # date Fri Jan 11 18:04:10 CST 2020设置时间 # date -s "19:20:30"设置日期+时间 # date -s " ...
- CVE-2020-0796 RCE复现
虽然热度已经过了,之前留的笔记发(水)一篇博客 影响版本 适用于32位系统的Windows 10版本1903 Windows 10 1903版(用于基于x64的系统) Windows 10 1903版 ...
- 关于 RocketMQ 事务消息的正确打开方式 → 你学废了吗
开心一刻 昨晚和一哥们一起吃夜宵,点了几瓶啤酒 不一会天空下起了小雨,哥们突然道:糟了 我:怎么了 哥们:外面下雨了,我老婆还在等着我去接她 他给了自己一巴掌,说道:真他妈不是个东西 我心想:哥们真是 ...