提取器是从表达式中获取值
第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) }
时间: 2024-12-19 17:15:36