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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第28讲:Scala提取器Extractor实战详解相关的知识,希望对你有一定的参考价值。

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

第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中的Extractor对象和类

Json提取器(Json Extractor)

后置处理器:Regular Expression Extractor

第24讲: Scala中SAM转换实战详解

JMETER CSS JQUERY EXTRACTOR

第26讲: Scala中的模式匹配入门实战详解