关于Scala中的正则表达式与模式匹配结合的正则表达式Reg

正则表达式的实现:正则表达式的定义与其它语言差不多,只需在表达式后加一个.r,并且可以遍历相应的表达式进行匹配

    //定义的正则表达式
val regex="""([0-9]+) ([a-z]+)""".r //由数字与字母组成的常量
val numPattern = "[0-9]+".r //由数字组成的常量
val numberPattern = """\s+[0-9]+\s+""".r //由s与数字+s组成的正则表达式
println(regex);
// findAllIn方法返回遍历所有匹配项的迭代器
for (matchString <- numPattern.findAllIn("99345 Scala, 22298 Spark")) println(matchString)
// 找到首个匹配项
println(numberPattern.findFirstIn("99ss java, 222 hadoop"))

与模式匹配结合的Reg实现:在今后可能会经常使用正则表达式与模式匹配进行组合

 //正则表达式与模式匹配结合
val numitemPattern="""([0-9]+) ([a-z]+)""".r //正则表达式
val numitemPattern(num, item) = "99 hadoop" //规定模式
val line = "93459 spark"
line match{
case numitemPattern(num, blog) => println(num + "\t" + blog)
case _ => println("Oops...")
}

Scala中本地函数与一等公民函数

本地函数实现:就是函数中包括函数,这样使函数更加安全。

  //本地函数 就是函数中包含函数 这样就可以使里面的函数使用外面函数的参数
def processData(filename: String, width: Int) {
def processLine(line: String) {
if (line.length > width)
println(filename +": "+ line)
}
val source = Source.fromFile(filename)
for (line <- source.getLines)
processLine(line)
}
}

作为一等公民函数实现;能让函数表示式能够更加方便的在编程中使用

  //一等公民函数
def main(args: Array[String]): Unit = {
//启动项中设置的参数
val width = args(0).toInt
for (arg <- args.drop(1))
processData(arg, width)
var increase = (x: Int) => x + 1
println(increase(10))
increase = (x: Int) => x + 9999
val someNumbers = List(-11, -10, -5, 0, 5, 10)
//遍历数组
someNumbers.foreach((x: Int) => print (x))
println
//过滤大于0
someNumbers.filter((x: Int) => x > 0).foreach((x: Int) => print (x))
println
//过滤大于0
someNumbers.filter((x) => x > 0).foreach((x: Int) => print (x))
println
//过滤大于0
someNumbers.filter(x => x > 0).foreach((x: Int) => print (x))
println
//过滤大于0
someNumbers.filter(_ > 0).foreach((x: Int) => print (x))
println
//定义两个数字相加
val f = (_: Int) + (_: Int)
println(f(5, 10)) }

Scala中偏函数讲解

偏函数实现:偏函数能够让表达式更加简洁,没有必要写多余的参数

偏函数解析:偏函数实现的时候会生成对于的apply函数来进行相应的操作

    val data = List(1, 2, 3, 4, 5, 6)
//使用偏函数来遍历list 使用空格+_
data.foreach(println _)
data.foreach(x => println(x))
def sum(a: Int, b: Int, c: Int) = a + b + c
println(sum(1, 2, 3))
val fp_a = sum _
//直接调用定义sum函数 ,调用它相应的apply函数
println(fp_a(1, 2, 3))
println(fp_a.apply(1, 2, 3))
val fp_b = sum(1, _: Int, 3)
println(fp_b(2))
println(fp_b(10))
data.foreach(println _)
data.foreach(println)

Scala中关于闭包讲解

Scala闭包解析:让函数体用简单的表达式来实现冗余的事情

Scala闭包实现

    def main(args: Array[String]) {

    val data = List(1, 2, 3, 4, 5, 6)
var sum = 0
data.foreach(sum += _)
def add(more: Int) = (x: Int) => x + more
val a = add(1)
val b = add(9999)
println(a(10)) println(b(10)

Scala的函数式编程真的是博大精深啊,很多东西都被他的底层所实现了,这让我们在使用过程中能更加简洁了。今天就到这儿

欢迎大家观看 王家林老师的大数据相关视频....

王家林微信号:18610086859

最新视频72讲:http://pan.baidu.com/s/1qWsq6Jy

该博客的视频19-22讲:http://pan.baidu.com/s/1o63QbPo

大数据系列修炼-Scala课程06的更多相关文章

  1. 大数据系列修炼-Scala课程01

    简介 由于本人刚毕业,也是从事软件开发相关的工作.想再学习一下关于大数据.移动互联网.云计算相关的技术.为我的未来打好基础.并且从零开始学习大数据相关的知识,脚踏实地的走好每一步,听行业前辈说毕业生刚 ...

  2. 大数据系列修炼-Scala课程03

    前言 今天上班看了很多关于前端js,jQuery.bootstrap.js以及springMVC看得迷迷糊糊的,毕竟以前很少去学习前端的技术,所有看得有点困,还好看得比较多,回家后也开始学习关于Sca ...

  3. 大数据系列修炼-Scala课程07

    由于昨天下班后有点困,就没有来及写博客,今天会把它补上!把这个习惯坚持下去! 关于Scala高阶函数详解 1.Scala高阶函数代码实现:高阶函数就是在我们函数中套用函数 2.高阶函数代码详解:高阶函 ...

  4. 大数据系列修炼-Scala课程04

    Scala中继承实现:超类的构造.字段重写.方法重写 关于超类的构建:超类可以在子类没有位置的限制,可以在子类中调用父类的方法 类中字段重写:在重写字段前面加一个override就可以重新赋值 类中方 ...

  5. 大数据系列修炼-Scala课程08

    接下来会讲解关于各种模式匹配,从中就会知道模式匹配的重要性 关于Type.Array.List.Tuple模式解析 1.Type模式匹配代码解析 //关于Type类型的模式匹配 //匹配 Int类型. ...

  6. 大数据系列修炼-Scala课程02

    Scala数组操作实战详解 接着昨天的课程,下面我们继续学习关于Scala数组操作详解.Scala数组的定义 //数组定义 //定长数组格式 /** * val arrayName = new Arr ...

  7. 大数据系列修炼-Scala课程11

    接着昨天的list,也是学习集合的相关知识 ListBuffer.ArrayBuffer.Queue.stack相关操作 1.ListBuffer.ArrayBuffer代码实现:ListBuffer ...

  8. 大数据系列修炼-Scala课程10

    今天主要是关于Scala中对List的相关操作,list在Scala中应该是至关重要,接下来会讲解关于List的一系列操作 List的map.flatMap.foreach.filter操作讲解 1. ...

  9. 大数据系列修炼-Scala课程05

    Scala多重继承.构造器的执行顺序.AOP实现 多重继承的trait实现:Scala中接口可以继承具体的类,trait接口可以实现多重继承,并且某个类也可以继承特定的类,在继承后面可以混入,接口的实 ...

随机推荐

  1. 国内三大PTPrivate Tracker站分析

    除这一行外,下面全部内容都是转载.出处不明. 国内三大PT(Private Tracker)站分析 先郑重的声明一下:本文以下的内容所有是复制粘贴的,不代表老夫的观点. 事实上内容我也没细致看. 贴这 ...

  2. Heibernate 入门笔记(一)---第一个demo

    最近在学heibernate,是看马士兵老师的视频学的,在这里总结一下,做点笔记.关于heibernate的优点,大家可以在网上 百度,这里不做赘述,直接讲怎么使用heibernate 步骤一:新建项 ...

  3. Gradle 1.12 翻译——第十六章. 使用文件

    有关其它已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或訪问:http://gradledoc.qiniudn.com ...

  4. eclipse报错:发现了以元素 'd:skin' 开头的无效内容。此处不应含有子元素

    Console报错: sdk\system-images\android-22\android-wear\armeabi-v7a\devices.xml cvc-complex-type.2.4.d: ...

  5. [LeetCode217]Contains Duplicate

    题目:Given an array of integers, find if the array contains any duplicates. Your function should retur ...

  6. hdu1004----用java链表实现

    Let the Balloon Rise Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Oth ...

  7. 【DataStructure】Some useful methods about linkedList(三)

    Method 4: Gets the value of element number i For example, if list is {22, 33, 44, 55, 66, 77, 88, 99 ...

  8. Windows 8实例教程系列 - 数据绑定基础实例

    原文:Windows 8实例教程系列 - 数据绑定基础实例 数据绑定是WPF,Silverlight以及Windows Phone应用开发中最为常用的开发技术,在基于XAML的Windows Stor ...

  9. MVC—WebAPI(调用、授权)

    ASP.NET MVC—WebAPI(调用.授权)   本系列目录:ASP.NET MVC4入门到精通系列目录汇总 微软有了Webservice和WCF,为什么还要有WebAPI? 用过WCF的人应该 ...

  10. apk反编译工具-apktool

    apk很easy被反编译,关于这篇文章apktool反编译工具. (一)优势反编译 1.能学习别人优秀代码 看看优秀apk他们的string.color命名规则,看看布局排版等都能学习到东西. 2.进 ...