专栏首页数据科学学习手札(数据科学学习手札49)Scala中的模式匹配
原创

(数据科学学习手札49)Scala中的模式匹配

一、简介

  Scala中的模式匹配类似Java中的switch语句,且更加稳健,本文就将针对Scala中模式匹配的一些基本实例进行介绍:

二、Scala中的模式匹配

2.1 基本格式

  Scala中模式匹配的基本格式如下:

  data match {

       case ... => 执行语句

       case ... => 执行语句

       case _  => 执行语句

}

  其中,data表示将要进行模式匹配的对象,match是模式匹配的关键字,后面紧跟的{}中包含若干条匹配的方向,且只会匹配其中满足条件的第一条;对于每一条条件,都是以case关键字开头,紧跟匹配的模式,且_表示匹配任何模式,接着是=>,指向对应的执行语句,下面是一个简单的示例:

object main{
  def main(args: Array[String]): Unit = {
    var data:String = "Hadoop"
    //模式匹配语句
    data match {
      case "Spark" => println("No!")
      case "Hadoop" => println("Yes")
    }
    var demo = 1 match {
        //通配符_表示匹配任何对象
      case _ => println("Anything!")
    }
  }
}

  可以看出,在第一个模式匹配语句中,匹配到对应的"Hadoop"字符串对象之后,执行了对应的语句;在第二个模式匹配语句中,_指定了匹配任意对象,并执行了对应的输出;

2.2 结合条件语句

  在我们的模式匹配语句中,可以添加条件语句,在Scala中这叫做守卫,下面是一个简单的例子:

object main{
  def main(args: Array[String]): Unit = {

    def isMale(Gender:Int)={
      Gender match {
        case 1 => println("Yes!Male!")
        case 0 => println("No!Female!")
          //添加守卫的模式匹配语句
        case _ if Gender != 0 & Gender != 1 => println("Unknown!")
      }
    }
    //调用函数
    isMale(0)
    isMale(1)
    isMale(2)
  }
}

2.3 结合变量

  在Scala的模式匹配中,我们还可以在模式语句内直接赋以新变量,来与传入的变量结合起来,对上面的例子稍加改造得到下面这个例子:

object main{
  def main(args: Array[String]): Unit = {

    def isMale(Gender:Int)={
      Gender match {
        case 1 => println("Yes!Male!")
        case 0 => println("No!Female!")
          //添加守卫的模式匹配语句
        case gender if gender != 0 & gender != 1 => {
          println("Unknown!")
          //在match语句中调用新变量
          println("gender = " + gender)
        }
      }
    }
    //调用函数
    isMale(2)
  }
}

  可以看出,将match语句下的模式匹配内容由常量改成新变量,会直接将传入的待匹配对象传递给该新变量,但该新变量的作用域只限于match语句内,在外无法调用;

2.4 匹配数组与元组

数组:

  在对数组进行模式匹配时,可以配合通配符完成一些模糊匹配的功能:

import scala.collection.mutable.ArrayBuffer

object main{
  def main(args: Array[String]): Unit = {

    val Demo = ArrayBuffer("Spark","Scala","Python")
    Demo match {
      case ArrayBuffer("Scala") => println("No!")
      case ArrayBuffer("Spark",_*) => println("Yes!")
      case _ => println("Warning!")
    }
  }
}

  通过在匹配内容中添加_*,来表示匹配任意多的数组元素,这这里表示匹配第一个元素时"Spark",之后任意多其他元素的可变长数组;

元组:

  在匹配元组时,同样可以使用对应的语法来实现模糊匹配:

object main{
  def main(args: Array[String]): Unit = {
    def fitTuple(tuple:Tuple2[Any,Any]): Unit ={
      tuple match {
        case (1,"Spark") => println("1")
          //匹配第二个元素为Scala的长度为2的元组
        case (x,"Scala") => println(x)
        case _ => println("Nothing!")
      }
    }
    val t = (3,"Scala")
    fitTuple(t)
  }
}

2.5 异常处理与模式匹配

  在前面的(数据科学学习手札45)Scala基础知识中提到过Scala中的错误处理机制,其实catch{}语句中的各条执行语句就是一条条的模式匹配语句,这里便不再赘述。

  以上就是Scala中关于模式匹配的一些基础内容的简单介绍,如有笔误,望指出。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • xpath进阶用法

      xpath作为对网页、对xml文件进行定位的工具,速度快,语法简洁明了,在网络爬虫解析内容的过程中起到很大的作用,除了xpath的基础用法之外xpath中还...

    Feffery
  • (数据科学学习手札23)决策树分类原理详解&Python与R实现

      作为机器学习中可解释性非常好的一种算法,决策树(Decision Tree)是在已知各种情况发生概率的基础上,通过构成决策树来求取净现值的期望值大于等于零的...

    Feffery
  • (数据科学学习手札94)QGIS+Conda+jupyter玩转Python GIS

    QGIS随着近些年的发展,得益于其开源免费的特点,功能不断被世界各地的贡献者们开发完善,运算速度也非常出色,使得越来越多的Giser们从臃肿缓慢的Arcgis...

    Feffery
  • MongoDB触发oom-killer的简单处理(一)(r7笔记第54天)

    今天正在处理问题,突然收到一封邮件,提示mongo的一个副本集出现了问题。邮件内容如下: 当前状态:PROBLEM 事件编号:11187790 发生时间:201...

    jeanron100
  • 【NLP】初次BERT使用者的可视化指南

    用可视化的方式演示了如何用Bert来做一个句子分类的应用,每一步都有非常详细的图解,特别的清楚。

    yuquanle
  • GCD swift dispatch_set_target_queue 小例

    let  Queue1  = DispatchQueue(label:"Queue1")

    ZY_FlyWay
  • 快讯:Oracle自治事务处理数据库发布和19c路线图

    此前 Oracle 已经发布了 Autonomous Data Warehouse 服务(ADW),现在 Autonomous Transaction Proc...

    数据和云
  • python相关包无法pip时 原

    通常可以直接google “XXX for python3.5”,或者在github中找到对应的python3.5的项目,将对应的.py文件添加到python的...

    晓歌
  • php让json_encode不自动转义斜杠“/”的方法

    hp中怎么让json_encode不自动转义斜杠“/”?下面本篇文章给大家介绍一下PHP中让json_encode不自动转义斜杠“/”的方法。

    砸漏
  • django orm模块中的 is_delete用法

    数据库删除数据咱都知道,简单的说就是当一条数据对企业没用后,一般人可能会选择删除这条数据。

    砸漏

扫码关注云+社区

领取腾讯云代金券