首页 > 其他 > 详细

第28讲:Scala提取器Extractor实战详解

时间:2016-02-14 22:25:13      阅读:250      评论:0      收藏:0      [点我收藏+]

提取器是从表达式中获取值

第27讲中的match代码也是一种提取器

    def match_array(arr : Any) = arr match {
      case Array(x) => println("Array(1):",x) // 长度为1的数组,x代表数组中的值
      case Array(x,y) =>  println("Array(2):",x,y) // 长度为2的数组,x代表数组中的第一个值
      case Array(x,_*) => println("任意一维数组:",x) //任意长度数组,取第一个值
      case Array(_*) => println("任意一维数组") //任意长度数组
     }
     
    match_array(Array(0))
    match_array(Array("spark"))
    match_array(Array("spark","scala"))
    match_array(Array("spark","scala",0,4))

将数组中的元素提取给case中定义的常量,例如x,y 


还有一个使用正则表达式提取数据的提取器

    val pattern = "([0-9]+) ([a-z]+)".r
    "2016 spark" match {
      case pattern(num,item) => println(num+" "+item)
    }



本文出自 “叮咚” 博客,请务必保留此出处http://lqding.blog.51cto.com/9123978/1741929

第28讲:Scala提取器Extractor实战详解

原文:http://lqding.blog.51cto.com/9123978/1741929

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!