Scala系列 (四)Scala数组功能分类整理---更利于记忆与理解运用实战!!

写在前面: 我是「nicedays」,一枚喜爱做特效,听音乐,分享技术大数据开发猿。这名字是来自world order乐队的一首HAVE A NICE DAY。如今,走到现在很多坎坷和不顺,如今终于明白nice day是需要自己赋予的。
白驹过隙,时光荏苒,珍惜当下~~
写博客一方面是对自己学习的一点点总结及记录,另一方面则是希望能够帮助更多对大数据感兴趣的朋友。如果你也对 大数据与机器学习感兴趣,可以关注我的动态 https://blog.csdn.net/qq_35050438,让我们一起挖掘数据与人工智能的价值~

数组函数分类:

分区类函数:


partition(p: (T) ⇒ Boolean): (Array[T], Array[T])

  • 由于返回的是布尔值,所以只能返回两个区 (Array[T], Array[T])
 val a = Array(1, 2, 3, 4, 5)
 val b:(Array[Int],Array[Int]) = a.partition( {x:Int => x % 2 == 0})
 println(b._1.mkString(","))     // return  2,4
 println(b._2.mkString(","))     // return  1,3,5

在这里插入图片描述
groupBy[K](f: (T) ⇒ K): Map[K, Array[T]]

  • 按条件分组,条件由 f 匹配,返回值是Map类型,每个key对应一个序列,下面代码实现的是,把小于3的数字放到一组,大于3的放到一组,返回Map[String,Array[Int]]
    val a = Array(1, 2, 3,4)
    val b = a.groupBy( x => x match {
      case x if (x < 3) => "small"
      case _ => "big"
    })

grouped(size: Int): collection.Iterator[Array[T]]

  • 按指定数量分组,每组有 size 数量个元素,返回一个集合迭代器
val a = Array(1, 2, 3,4,5)
val b = a.grouped(3).toList
b.foreach((x) => println("第"+(b.indexOf(x)+1)+"组:"+x.mkString(",")))
/**
第1组:1,2,3
第2组:4,5
*/

span(p: (T) ⇒ Boolean): (Array[T], Array[T])

  • 分割序列为两个集合,从第一个元素开始,直到找到第一个不满足条件的元素止,之前的元素放到第一个集合,其它的放到第二个集合
    val a = Array(3,2,1,4,5)
    val b = a.span( {x:Int => x > 2})
    println(b._1.mkString(","))     //  3
    println(b._2.mkString(","))     //  2,1,4,5

排序类函数:


sortBy[B](f: (T) ⇒ B)(implicit ord: math.Ordering[B]): Array[T]

  • 按指定的排序规则排序

  • 如果数组里有数字有字符串,排序会报错

    val a = Array(3,2,1,4,5)
    val b = a.sortBy( {x:Int => x})// 升序
	val b1 = a.sortBy( {x:Int => 0-x})// 降序
    println(b.mkString(","))    // 1,2,3,4,5

sortWith(lt: (T, T) ⇒ Boolean): Array[T]

  • 自定义排序方法
  • 当数组里有数字有字符串就先转字符在判断
    val a = Array(3,2,1,4,5)
    val b = a.sortWith(_.compareTo(_) > 0)  // 大数在前

    println(b.mkString(","))    // 5,4,3,2,1

在这里插入图片描述

取值类函数:


apply(i: Int): T

  • 取出指定索引处得元素
arr.apply(index)

head()

  • 拿头元素
arr.head

last()

  • 拿尾元素
arr.last

init: Array[T]

  • 返回当前序列中不包含最后一个元素的序列
val a = Array(10, 2, 3, 40, 5)
val b = a.init
println(b.mkString(","))    // 10, 2, 3, 40

tail()

  • 去头元素
 val a = Array(10, 2, 3, 40, 5)
 val b = a.tail
 println(b.mkString(","))    // 2, 3, 40,5

slice(from: Int, until: Int): Array[T]

  • 取出当前序列中,from 到 until 之间的片段
    val a = Array(1,2,3,4,5)
    val b = a.slice(1,3)
    println(b.mkString(","))    // 2,3

take(n: Int): Array[T]

  • 返回当前序列中前 n 个元素组成的序列
 val a = Array(1,2,3,4,5)
 val b = a.take(3)       //  1,2,3

takeRight(n: Int): Array[T]

val a = Array(1,2,3,4,5)
val b = a.takeRight(3)      //  3,4,5

subSequence(start: Int, end: Int): CharSequence

  • 返回start和end间的字符序列
val chars = Array('a','b','c','d')
val b = chars.subSequence(1,3)
println(b.toString)     //  bc

断言类函数:

canEqual(that: Any): Boolean

  • 判断两个对象是否可以进行比较
arr.canEqual()

contains[A1 >: A](elem: A1): Boolean

  • 序列中是否包含指定对象
arr.contains(2)

containSlice[B](that: GenSeq[B]): Boolean

  • 判断当前序列中是否包含另一个序列
val a = List(1,2,3,4)
val b = List(2,3)
println(a.containsSlice(b))  //true

corresponds[B](that: GenSeq[B])(p: (T, B) ⇒ Boolean): Boolean

  • 判断两个序列长度以及对应位置元素是否符合某个条件。如果两个序列具有相同的元素数量并且对应位置得条件都成立,返回结果为true
val a = Array(1, 2, 3)
val b = Array(4, 5,6)
println(a.corresponds(b)(_<_))  //true

endsWith[B](that: GenSeq[B]): Boolean

  • 判断是否以某个序列结尾
val a = Array(3, 2, 3,4)
val b = Array(3,4)
println(a.endsWith(b))  //true

exists(p: (T) ⇒ Boolean): Boolean

  • 判断当前数组是否包含符合条件的元素
 val a = Array(3, 2, 3,4)
 println(a.exists( {x:Int => x==3} ))   //true
 println(a.exists( {x:Int => x==30} ))  //false

forall

  • 对集合中的元素进行某个判断,全部为true则返回true,反之返回false
scala> var s = List("hello", "world")
s: List[String] = List(hello, world)

scala> s.forall( f => f.contains("h") )
res34: Boolean = false

scala> s.forall( f => f.contains("o") )
res35: Boolean = true

exist

  • 对集合中的元素进行某个判断,其中之一符合条件则返回true,反之返回false。和forall是一个对应的关系,相当于 and 和 or。
scala> s.exists( f => f.contains("h") )
res36: Boolean = true

hasDefiniteSize: Boolean

  • 检测序列是否存在有限的长度,对应Stream这样的流数据,返回false
val a = Array(1, 2, 3,4,5)
println(a.hasDefiniteSize)  //true

isDefinedAt(idx: Int): Boolean

  • 判断序列中是否存在指定索引
 val a = Array(1, 2, 3, 4, 5)
 println(a.isDefinedAt(1))   // true
 println(a.isDefinedAt(10))  // false

isEmpty: Boolean

  • 判断当前序列是否为空

isTraversableAgain: Boolean

  • 判断序列是否可以反复遍历

在这里插入图片描述

nonEmpty: Boolean

  • 判断序列不是空

startWith[B](that: GenSeq[B], offset: Int): Boolean

  • 从指定偏移处,是否以某个序列开始
    val a = Array(0,1,2,3,4,5)
    val b = Array(1,2)
    println(a.startsWith(b,1))      //  true

sameElements(that: GenIterable[A]): Boolean

  • 判断两个序列是否顺序和对应位置上的元素都一样

过滤类函数:

按条件对数组进行某种操作,拿到我想要拿到得值或数组

collect[B](pf: PartialFunction[A, B]): Array[B]

  • 执行一个并行计算,得到一个新的数组对象
   val chars = Array('a','b','c')
   val newchars = chars.collect(fun)
   println("newchars:"+newchars.mkString(","))
  //我们通过下面的偏函数,把chars数组的小写a转换为大写的A
  val fun:PartialFunction[Char,Char] = {
    case 'a' => 'A'
    case x => x
  }
  /**输出结果是 newchars:A,b,c */

在这里插入图片描述

val newchars = Array(22,442,653,3467)
val fun:PartialFunction[Char,Char] = {
	case y if %  2 == 0 =>  y + 5
}

在这里插入图片描述

filter(p: (T) ⇒ Boolean): Array[T]

  • 取得当前数组中符合条件的元素,组成新的数组返回
val a = Array(3, 2, 3, 4)
val b = a.filter( {x:Int => x > 2} )
println(b.mkString(","))    //3,3,4

flatMap[B](f: (A) ⇒ GenTraversableOnce[B]): Array[B]

  • flat和map,先map后flatten、
  • map一般都会形成嵌套集合,需要flat扁平化
val a = Array(1, 2, 3,4)
val b = a.flatMap(x=>1 to x)
println(b.mkString(","))
/**
1,1,2,1,2,3,1,2,3,4
从1开始,分别于集合a的每个元素生成一个递增序列,过程如下
1
1,2
1,2,3
1,2,3,4
*/

在这里插入图片描述

map[B](f: (A) ⇒ B): Array[B]

  • 对序列的元素进行操作

wordcount:

在这里插入图片描述

takeWhile(p: (T) ⇒ Boolean): Array[T]

val a = Array(1,2,3,4,5)
val b = a.takeWhile( {x:Int => x < 3})      //  1,2

distinct: Array[T]

  • 去除当前集合得重复元素
val a = Array(1, 2, 3,4,4,5,6,6)
val c = a.distinct
println(c.mkString(","))    // 1,2,3,4,5,6

drop(n: Int): Array[T]

  • 当前序列中前 n 个元素去除
val a = Array(1, 2, 3,4)
val c = a.drop(2)
// 3,4

dropRight(n: Int): Array[T]

  • 当前序列中尾部n 个元素去除

dropWhile(p: (T) ⇒ Boolean): Array[T]

  • 去除符合条件得元素
  • 但是有一个条件:从当前数组的第一个元素起,就要满足条件,直到碰到第一个不满足条件的元素结束(即使后面还有符合条件的元素)
//下面去除大于2的,第一个元素 3 满足,它后面的元素 2 不满足,所以返回 2,3,4
val a = Array(3, 2, 3,4)
val c = a.dropWhile( {x:Int => x > 2} )
println(c.mkString(","))
 
//如果数组 a 是下面这样,第一个元素就不满足,所以返回整个数组 1, 2, 3,4
val a = Array(1, 2, 3,4) 

拼接类函数:


addString(b: StringBuilder,sep: String): StringBuilder

val a = List(1,2,3,4)
val b = new StringBuilder("678")
val c = a.addString(b)   // c中的内容是  1234
val d = a.addString(b,",") // 连接字符串时每个元素按分隔符隔开 
val e = a.addString(b,"shou",",","wei") // 在首尾各加一个字符串,并指定sep分隔符

在这里插入图片描述

+:与:+: (elem: A): Array[A]

  • 在数组前添加一个元素
val k = 0
val a = List(1,2)
val c = k +: a // c中的内容是 (0,1,2)
val d = a :+ k // d中的内容是 (1,2,0)
数组在哪冒号在哪

mkString: String

  • 将所有元素组合成字符串,以xx做分隔符

聚合类函数:


/:与:\ (z: B)(op: (B, T) ⇒ B): B–foldleft的简写

  • 对数组中所有的元素进行相同的操作
val a = List(1,2,3,4)
val c = (10 /: a)(_+_)   // 1+2+3+4+10
val d = (10 /: a)(_*_)   // 1*2*3*4*10
println("c:"+c)   // c:20
println("d:"+d)   // d:240
冒号在哪边,集合就在哪边

aggregate[B](z: ⇒ B)(seqop: (B, T) ⇒ B, combop: (B, B) ⇒ B): B

  • 聚合计算,aggregate是柯里化方法,参数是两个方法

fold[A1 >: A](z: A1)(op: (A1, A1) ⇒ A1): A1

  • 对序列中的每个元素进行二元运算
  def seqno(m:Int,n:Int): Int ={
    val s = "seq_exp=%d+%d"
    println(s.format(m,n))
    return m+n
  }
  def combine(m:Int,n:Int): Int ={
    val s = "com_exp=%d+%d"
    println(s.format(m,n))
    return m+n
  }
    val a = Array(1, 2, 3,4)
    val b = a.fold(5)(seqno)
    /** 运算过程
    seq_exp=5+1
    seq_exp=6+2
    seq_exp=8+3
    seq_exp=11+4
    */
    val c = a.par.aggregate(5)(seqno,combine)
    /** 运算过程
    seq_exp=5+1
    seq_exp=5+4
    seq_exp=5+3
    com_exp=8+9
    seq_exp=5+2
    com_exp=6+7
    com_exp=13+17
    */

foldRight[B](z: B)(op: (B, T) ⇒ B): B

  def seqno(m:Int,n:Int): Int ={
    val s = "seq_exp=%d+%d"
    println(s.format(m,n))
    return m+n
  }
    val a = Array(1, 2, 3,4)
    val b = a.foldRight(5)(seqno)
    /** 运算过程
    seq_exp=4+5
    seq_exp=3+9
    seq_exp=2+12
    seq_exp=1+14
    */
    /**
    简写 (a :\ 5)(_+_)
    */

reduce[A1 >: A](op: (A1, A1) ⇒ A1): A1

  • 同 fold,不需要初始值
  • 只处理数据的一部分为偏函数
val a = Array(1,2,3,4,5)
val b = a.reduce(seqno)// 直接聚合
println(b)    // 15
  /**
    seq_exp=1+2
    seq_exp=3+3
    seq_exp=6+4
    seq_exp=10+5
  */
reduce(_+_)// 用拿到的两参数相加`

scan[B >: A, That](z: B)(op: (B, B) ⇒ B)(implicit cbf: CanBuildFrom[Array[T], B, That]): That

  • 用法同 fold,scan会把每一步的计算结果放到一个新的集合中返回,而 fold 返回的是单一的值
  val a = Array(1,2,3,4,5)
  val b = a.scan(5)(seqno)
  println(b.mkString(","))    // 5,6,8,11,15,20

交集,并集,差集:


intersect(that: collection.Seq[T]): Array[T]

  • 取两个集合的交集
  val a = Array(1, 2, 3, 4, 5)
  val b = Array(3, 4, 6)
  val c = a.intersect(b)
  println(c.mkString(","))    //return 3,4

diff(that: collection.Seq[T]): Array[T]

  • 返回当前数组与另一个数组比较后独一无二得元素
val a = Array(1, 2, 3,4)
val b = Array(4, 5,6,7)
val c = a.diff(b)
println(c.mkString) //1,2,3

++

  • 合并数组
var c = Array(1,2,3)
var b = Array(4,5,6)
b++c

++:

  • 合并数组 并将右边的类型作为最终结果返回
 val a = List(1,2)
 val b = scala.collection.mutable.LinkedList(3,4)
 val c = a ++: b
// 最后c为LinkList类型

排列组合函数;

combinations(n: Int): collection.Iterator[Array[T]]

  • 拿到数组对应长度得所有排列组合
val arr = Array("a","b","c")
val newarr = arr.combinations(2)// 返回了一个迭代器,长度为2得排列组合
newarr.foreach((item) => println(item.mkString(",")))
 /**
    a,b
    a,c
    b,c
 */

permutations: collection.Iterator[Array[T]]

  • 排列组合,他与combinations不同的是,组合中的内容可以相同,但是顺序不能相同,combinations不允许包含的内容相同,即使顺序不一样
    val a = Array(1, 2, 3, 4, 5)
    val b = a.permutations.toList   // b 中将有120个结果,知道排列组合公式的,应该不难理解吧
    /**如果是combinations*/
    val b = a.combinations(5).toList    // b 中只有一个,因为不管怎样排列,都是这5个数字组成,所以只能保留第一个

其他类函数:

charAt(index: Int): Char–字符数组才有

val chars = Array('a','b','c')
c.charAt()

clone(): Array[T]

  • 创建一个副本,不是引用,是深拷贝
val chars = Array('a','b','c')
val newchars = chars.clone()

copyToArray(xs: Array[A]): Unit

  • 数组中的内容拷贝到另外一个数组
// 将a得数组拷贝给b,得从索引2开始拷
a.copyToArray(b,2)

在这里插入图片描述
copyToBuffer[B >: A](dest: Buffer[B]): Unit

 val a:ArrayBuffer[Char]  = ArrayBuffer()
    b.copyToBuffer(a)
    println(a.mkString(","))

在这里插入图片描述

count(p: (T) ⇒ Boolean): Int

  • 统计符合条件的元素个数,x>2 大于2才做统计
  • 下面统计大于 2 的元素个数
val a = Array(1, 2, 3)
println(a.count({x:Int => x > 2}))  // count = 1

find(p: (T) ⇒ Boolean): Option[T]

  • 查找第一个符合条件得某个东西
val a = Array(1, 2, 3,4)
val b = a.find( {x:Int => x>2} )
// val b = a.find( x => x > 2 )
println(b)  // Some(3)
val b = a.find( {x:Int => x>2} ).get // 拿值

foreach(f: (A) ⇒ Unit): Unit

  • 遍历序列中的元素,进行 f 操作,类似迭代器,只能执行一次
    val a = Array(1, 2, 3,4)
    a.foreach(x => println(x*10))
    /**
    10
    20
    30
    40
    */

indexOf(elem: T, from: Int): Int

  • elem在序列中的索引,找到第一个就返回
val a = Array(1, 3, 2, 3, 4)
println(a.indexOf(3))   // return 1

// 返回elem在序列中的索引,可以指定从某个索引处(from)开始查找,找到第一个就返回
val a = Array(1, 3, 2, 3, 4)
println(a.indexOf(3,2)) // return 3

indexOfSlice[B >: A](that: GenSeq[B], from: Int): Int

  • 检测当前序列中是否包含另一个序列(that),并返回第一个匹配出现的元素的索引
 val a = Array(1, 3, 2, 3, 4)
 val b = Array(2,3)
 println(a.indexOfSlice(b))  // return 2

indexWhere(p: (T) ⇒ Boolean, from: Int): Int

  • 返回当前序列中第一个满足 p 条件的元素的索引,可以指定从 from 索引处开始
 val a = Array(1, 2, 3, 4, 5, 6)
 println(a.indexWhere( {x:Int => x>3},4))    // return 4

indices: collection.immutable.Range

 val a = Array(10, 2, 3, 40, 5)
 val b = a.indices
 println(b.mkString(","))    // 0,1,2,3,4

Iterator: collection.Iterator[T]

  • 对序列每个元素产生一个iterator

lastIndexOf(elem: T, end: Int): Int

  • 取序列最后一个等于ele元素的位置

lastIndexWhere(p: (T) ⇒ Boolean): Int

  • 从右边往左边找第一个满足条件的索引

lastOption: Option[T]

  • 返回当前序列最后一个对象(some或者none)

lengthCompare(len: Int): Int

  • 数组长度减括号里面的值,返回值

padTo(len: Int, elem: A): Array[A]

  • 比设定长度少,就补齐,多就减去
 val a = Array(1, 2, 3, 4, 5)
 val b = a.padTo(7,9)    //需要一个长度为 7  的新序列,空出的填充 9
 println(b.mkString(","))    // return  1,2,3,4,5,9,9

par: ParArray[T]

patch(from: Int, that: GenSeq[A], replaced: Int): Array[A]

  • 批量替换,第一个是开始位置,第三个替换数量个元素,第二个是将被替换成某序列
 val a = Array(1, 2, 3, 4, 5)
 val b = Array(3, 4, 6)
 val c = a.patch(1,b,2)
 println(c.mkString(","))    // return 1,3,4,6,4,5
    /**从 a 的第二个元素开始,取两个元素,即 2和3 ,这两个元素被替换为 b的内容*/

prefixLength(p: (T) ⇒ Boolean): Int

  • 给定一个条件 p,返回一个前置数列的长度,这个数列中的元素都满足 p
    val a = Array(1,2,3,4,1,2,3,4)
    val b = a.prefixLength( {x:Int => x<3}) // b = 2

product

  • 返回所有元素乘积的值—阶乘
    val a = Array(1,2,3,4,5)
    val b = a.product       // b = 120  (1*2*3*4*5)

reverse: Array[T]

  • 反转序列
val a = Array(1,2,3,4,5)
val b = a.reverse
println(b.mkString(","))    //5,4,3,2,1

reserveIterator: collection.Iterator[T]

  • 反向生成迭代

reserveMap[B](f: (A) ⇒ B): Array[B]

  • 同 map 方向相反

transpose[U](implicit asArray: (T) ⇒ Array[U]): Array[Array[U]]

  • 矩阵转换,二维数组行列转换
    val chars = Array(Array("a","b"),Array("c","d"),Array("e","f"))
    val b = chars.transpose
    println(b.mkString(","))

update(i: Int, x: T): Unit

  • 将序列中 i 索引处的元素更新为 x
    val a = Array(1,2,3,4,5)
    a.update(1,9)
    println(a.mkString(","))        //1,9,3,4,5

updated(index: Int, elem: A): Array[A]

    val a = Array(1,2,3,4,5)
    a.update(1,9)
    println(a.mkString(","))        //1,9,3,4,5

zip[B](that: GenIterable[B]): Array[(A, B)]

  • 将两个序列对应位置上的元素组成一个pair序列
    val a = Array(1,2,3,4,5)
    val b = Array(5,4,3,2,1)
    val c = a.zip(b)
    println(c.mkString(","))        //(1,5),(2,4),(3,3),(4,2),(5,1)

zipAll[B](that: collection.Iterable[B], thisElem: A, thatElem: B): Array[(A, B)]

  • 同 zip ,但是允许两个序列长度不一样,不足的自动填充,如果当前序列端,空出的填充为 thisElem,如果 that 短,填充为 thatElem
    val a = Array(1,2,3,4,5,6,7)
    val b = Array(5,4,3,2,1)
    val c = a.zipAll(b,9,8)         //(1,5),(2,4),(3,3),(4,2),(5,1),(6,8),(7,8)
 
    val a = Array(1,2,3,4)
    val b = Array(5,4,3,2,1)
    val c = a.zipAll(b,9,8)         //(1,5),(2,4),(3,3),(4,2),(9,1)

猜你喜欢

转载自blog.csdn.net/qq_35050438/article/details/107342967