scala元组及拉链操作

scala元组及拉链操作:

 

scala里面的元组是可是不同数据类型的

scala> ("scala",1)

res45: (String, Int) = (scala,1)

 

scala> val t = ("scala",100L,3.14,("spark",1))

t: (String, Long, Double, (String, Int)) = (scala,100,3.14,(spark,1))

 

scala> t._1                       //元组内空的提取,以下标为1开始,并用._后跟数字的方式进行提取内容

res46: String = scala

 

scala> t._3

res47: Double = 3.14

 

scala> t._4._1

res48: String = spark

 

scala> val t,(a,b,c,d) = ("scala",100L,3.14,("spark",1))            //可以定义元组时给予变量名,如 t,(a, b, c, d),使用时直接用变量名a,b,c,d即可访问对应内容

t: (String, Long, Double, (String, Int)) = (scala,100,3.14,(spark,1))

a: String = scala

b: Long = 100

c: Double = 3.14

d: (String, Int) = (spark,1)

 

scala> a

res49: String = scala

 

scala> val arr = Array(("tingting",1),("ningning",3),("huihui",5))

arr: Array[(String, Int)] = Array((tingting,1), (ningning,3), (huihui,5))

 

scala> val mp = arr.toMap

mp: scala.collection.immutable.Map[String,Int] = Map(tingting -> 1, ningning -> 3, huihui -> 5)

 

scala拉链操作:

scala> val arr1 = Array("dog","cat","mouse")

arr1: Array[String] = Array(dog, cat, mouse)

 

scala> val arr2 = Array(1,3,5)

arr2: Array[Int] = Array(1, 3, 5)

 

scala> arr1 zip arr2                     //拉链操作符

res50: Array[(String, Int)] = Array((dog,1), (cat,3), (mouse,5))

 

scala> arr2 zip arr1                     //拉链操作符

res51: Array[(Int, String)] = Array((1,dog), (3,cat), (5,mouse))

 

scala> arr1.zip(arr2)                     //拉链操作符

res52: Array[(String, Int)] = Array((dog,1), (cat,3), (mouse,5))

 

scala> val arr3 = Array(1,2,3,4,5)     //生成一个比arr1元素多的数组,用少的去zip多的

arr3: Array[Int] = Array(1, 2, 3, 4, 5)

 

scala> arr1 zip arr3                      //会把长的给截取掉了

res53: Array[(String, Int)] = Array((dog,1), (cat,2), (mouse,3))

 

posted @ 2019-09-18 10:42  cindy_zl  阅读(662)  评论(0编辑  收藏  举报