码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2016-02-14 22:26:37      阅读:311      评论:0      收藏:0      [点我收藏+]

标签:scala提取器

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

第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实战详解

标签:scala提取器

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!