Scala(四) —— 集合
一、List
var x = List(1,2,3,4)
//x:List[Int] = List(1, 2, 3, 4)
var y = List("x","y","z")
//y: List[String] = List(x, y, z)
0 :: x
//res6: List[Int] = List(0, 1, 2, 3, 4)
x ::: y
//List[Any] = List(1, 2, 3, 4, x, y, z)
scala> "x"::"y"::"z"::Nil
res9: List[String] = List(x, y, z)
x.head //获取第一个元素
x.tail //获取除第一个元素的其他元素
x.isEmpty //判断该列表是否为空
字符串转List
var a = "HelloWorld,2018"
//a: String = HelloWorld,2018
a.toList
//res0: List[Char] = List(H, e, l, l, o, W, o, r, l, d, ,, 2, 0, 1, 8)
filter函数
a.toList.filter(x => Character.isDigit(x))
res1: List[Char] = List(2, 0, 1, 8)
//另一种简写方式
a.toList.filter(_.Character.isDigit(x))
takeWhile函数
a.toList.takeWhile(x => x!='d')
res2: List[Char] = List(H, e, l, l, o, W, o, r, l)
map函数
var a = List(1,2,3,4)
a.map(x => x % 2 == 0)
a.map(_%2 == 0)
var b = List(6,7,8)
var p = List(a,b)
a.map(_.filter(_%2 == 0))
//res14: List[List[Int]] = List(List(2, 4), List(8))
flatMap
a.flatMap(_.filter(_%2 == 0))
//res15: List[Int] = List(2, 4, 8)
reduce函数
a.reduce((x,y) => x+y)
//等价于
a.reduce(_+_)
foldLeft函数
a.fold(0)((x,y) => x+y)
//等价于
a.fold(0)(_+_)
二、Tuple元组
元组相当于数据库中的记录,可以放各种不同类型的值
val a = (1,2,3,4)
a._1 //访问元组中第一个元素
a._2 //访问元组中第二个元素
val b = (1,"fzj","math",95)
例子1:返回一条记录,计算一个列表的元素个数、元素之和,元素的平方和
val a = (1,2,3,4)
def sum(list:List[Int]):(Int,Int,Int)={
list.foldLeft(0,0,0)((x,y) => (x._1 + 1,x._2 + y,x._3 + y*y))
}
三、Set
var x = Set(1,2,3,4)
四、Map
(1) 创建Map
var x = Map("one" -> "1","two" -> "2")
var x:Map[String,String] = Map()
(2) 添加key-value
x += ("three" -> "three")
(3) 合并
使用 ++运算符 或 Map.++()方法来连接两个Map
var colors = color1 ++ color2
var colors = color1.++(color2)
(4) 遍历
val sites = Map("one"->"one","two"->"two","three"->"three")
sites.keys.foreach{
i =>
println("key="+i+",value="+sites(i))
}
Scala(四) —— 集合的更多相关文章
- 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(四)【集合基础入门】
目录 一.Array 二. List 三.Set 四.Tuple 五.Map 一.Array package com.bigdata.scala.day01 /** * @description: 不 ...
- Scala学习——集合
Scala集合 一.数组 package top.ruandb.scala.Course04 object ArrayApp { def main(args: Array[String]): Unit ...
- scala中集合的交集、并集、差集
scala中有一些api设计的很人性化,集合的这几个操作是个代表: 交集: scala> Set(1,2,3) & Set(2,4) // &方法等同于interset方法 sc ...
- 用Scala实现集合中相邻元素间的差值
欢迎转载,转载请注明出处,徽沪一郎. 概要 代码这东西,不写肯定不行,新学Scala不久,将实际遇到的一些问题记录下来,日后也好查找. 今天讲的是如何计算同一集合中元素两两之间的差值,即求开始集合(a ...
- 【Scala篇】--Scala中集合数组,list,set,map,元祖
一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组 1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...
随机推荐
- react.JS基础
1.ReactDOM.render() React.render 是 React 的最基本方法,用于将模板转为 HTML 语言,并插入指定的 DOM 节点. <!DOCTYPE html> ...
- web 10
一.Iterations : 1.do...while : 创建执行指定语句的循环,直到测试条件评估为false.在执行语句后评估条件,导致指定语句至少执行一次. 例子:在以下示例中,do...而循环 ...
- RCNN论文细节
写在前面: 本系列笔记主要记录本人在阅读过程中的收获,尽量详细到实现层次,水平有限,欢迎留言指出问题~ 这篇文章被认为是深度学习应用于目标检测的开山之作,自然是要好好读一下的,由于文章是前些日子读的, ...
- 在win10环境下搭建 solr 开发环境
在win10环境下搭建 solr 开发环境 2017年05月30日 09:19:32 SegaChen0130 阅读数:1050 在win10环境下搭建 solr 开发环境 安装环境 Windo ...
- JavaScript / 本地存储
cookie 首先让我们先了解一下,什么是cookie,cookie是浏览器提供的一种机制,他将document.cookie的接口提供给JavaScript使其可以对cookie进行控制,但cook ...
- pycharm 中 django 导入静态文件不提示补全
File—>setting----->Languages & Frameworks ------> Python Template Languages ------> ...
- SpringMVC的配置和使用
SpringMVC的配置和使用 什么是SpringMVC? SpringMVC是Spring家族的一员,Spring是将现在开发中流行的组件进行组合而成的一个框架!它用在基于MVC的表现层开发,类似于 ...
- 检测 web项目 404 500 状态的 页面
用于发版前自动化测试 用法 1.使用参数 -f 指定url配置文件2.url文件简单配置, 每行一条URL 下面三种格式都可以,如果不声明 GET.POST 默认为GET请求 https://www. ...
- Ansible配置免密登陆
0x01: 把远程服务器的公钥来获取到本地 #ssh-keyscan ip1 ip2 ip3 ip4 >> /root/.ssh/known_hosts 完成后,/root/.ssh/k ...
- Redis API的原子性分析
在学习Redis的常用操作时,经常看到介绍说,Redis的set.get以及hset等等命令的执行都是原子性的,但是令自己百思不得其解的是,为什么这些操作是原子性的? 原子性 原子性是数据库的事务中的 ...