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))

 

转载于:https://www.cnblogs.com/cindy-zl24/p/11540254.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值