Scala第十一章节(正则表达式和异常处理)

4. 正则表达式

4.1 概述

所谓的正则表达式指的是正确的,符合特定规则的式子, 它是一门独立的语言, 并且能被兼容到绝大多数的编程语言中。在scala中, 可以很方便地使用正则表达式来匹配数据。具体如下:

  1. Scala中提供了Regex类来定义正则表达式.
  2. 要构造一个Regex对象,直接使用String类的r方法即可.
  3. 建议使用三个双引号来表示正则表达式,不然就得对正则中的反斜杠进行转义.

4.2 格式

scala 复制代码
val 正则对象名="""具体的正则表达式""".r

注意: 使用findAllMatchIn方法可以获取到所有正则匹配到的数据(字符串).

4.3 示例一: 校验邮箱是否合法

需求
  1. 定义一个字符串, 表示邮箱.
  2. 定义一个正则表达式,来匹配邮箱是否合法.
  3. 合法邮箱测试:qq12344@163.com
  4. 不合法邮箱测试:qq12344@.com
  5. 打印结果.
参考代码
scala 复制代码
//案例:校验邮箱是否合法.
object ClassDemo13{
     def main(args:Array[String]):Unit={
  //需求:定义一个正则表达式,来匹配邮箱是否合法
  //1.定义一个字符串,表示邮箱.
  val email="qq12344@163.com"
  //2.定义一个正则表达式,用来校验邮箱.
  /*
    .表示任意字符
    +数量词,表示前边的字符出现至少1次,至多无所谓.
      @表示必须是@符号,无特殊含义.
    \.因为.在正则中有特殊的含义,所以要转移一下,使它变成普通的.  */
  val regex=""".+@.+\..+""".r
  //3.打印结果.
  if(regex.findAllMatchIn(email).size!=0){
   //合法邮箱
   println(s"${email}是一个合法的邮箱!")
     }else{
         println(s"${email}是一个非法的邮箱!")
  }
     }
}

4.4 示例二:过滤所有不合法邮箱

需求
  1. 找出以下列表中的所有不合法的邮箱.
  2. "38123845@qq.com", "a1da88123f@gmail.com", "zhansan@163.com", "123afadff.com"
参考代码
scala 复制代码
//案例:过滤所有不合法的邮箱.
object ClassDemo14{
     def main(args:Array[String]):Unit={
  //1.定义列表,记录邮箱.
val emlList=List("38123845@qq.com","a1da88123f@gmail.com","zhansan@163.com","123afadff.com")
  //2.定义正则表达式.
  valregex=""".+@.+\..+""".r
  //3.通过过滤器获取所有的不合法的邮箱.
  val list=emlList.filter(x=>regex.findAllMatchIn(x).size==0)  
  //4.打印结果.
  println(list)
     }
}

4.5 示例三:获取邮箱运营商

需求
  1. 定义列表, 记录以下邮箱:
mariadb 复制代码
"38123845@qq.com","a1da88123f@gmail.com","zhansan@163.com","123afadff.com"
  1. 使用正则表达式进行模式匹配,匹配出来邮箱运营商的名字。
markdown 复制代码
例如:
邮箱zhansan@163.com,需要将163(运营商的名字)
匹配出来.提示:
1. 使用括号来匹配分组.
2. 打印匹配到的邮箱以及运营商.
参考代码
scala 复制代码
//案例:获取邮箱运营商.
object ClassDemo15{
     def main(args:Array[String]):Unit={
  //1.定义列表,记录邮箱.
  val emlList=List("38123845@qq.com","a1da88123f@gmail.com","zhansan@163.com","123afadff.com")
           //2.定义正则表达式.
  val regex=""".+@(.+)\..+""".r
  //3.根据模式匹配匹配出所有合法的邮箱及其对应的运营商.
  val result=emlList.map{
   //email就是emlList这个列表中的每一个元素.
   //company表示:正则表达式中你用()括起来的内容,也就是分组的数据.   caseemail@regex(company)=>email->s"${company}"
   case email=>email->"未匹配"
  }
  //4.打印结果
  println(result)
     }
}

5. 异常处理

5.1 概述

来看看下面这一段代码:

scala 复制代码
def main(args: Array[String]): Unit = {
val i = 10 / 0
println("你好!")
}
Exception in thread "main" java.lang.ArithmeticException: / by zero
at ForDemo$.main(ForDemo.scala:3)
at ForDemo.main(ForDemo.scala)

执行程序,可以看到scala抛出了异常,而且没有打印出来"你好! "。说明程序出现错误后就终止了。 那怎么解决该问题呢? 在Scala中,可以使用异常处理来解决这个问题. 而异常处理又分为两种方式:

  • 方式一: 捕获异常.

注意: 该方式处理完异常后, 程序会继续执行.

  • 方式二: 抛出异常.

注意: 该方式处理完异常后, 程序会终止执行.

5.2 捕获异常

格式
scala 复制代码
try {
//可能会出现问题的代码
}
catch{
case ex:异常类型1 => //代码
case ex:异常类型2 => //代码
}
finally {
//代码
}

**解释: **

  1. try中的代码是我们编写的业务处理代码.
  2. 在catch中表示当出现某个异常时,需要执行的代码.
  3. 在finally中,写的是不管是否出现异常都会执行的代码.

5.3 抛出异常

我们也可以在一个方法中,抛出异常。格式如下:

格式
scala 复制代码
throw new Exception("这里写异常的描述信息")

5.4 示例

需求
  1. 通过try.catch来处理 除数为零异常.
  2. 在main方法中抛出一个异常.
参考代码
scala 复制代码
//案例: 演示异常处理.
object ClassDemo16 {
def main(args: Array[String]): Unit = {
//1. 通过try.catch来处理 除数为零异常.
try {
//可能出问题的代码
val i = 10 / 0
} catch {
//出现问题后的解决方案.
//case ex:Exception => println("代码出问题了!")
case ex:Exception => ex.printStackTrace()
}
println("你好!")
println("-" * 15) //我是分割线.
//2. 抛出一个异常对象.
throw new Exception("我是一个Bug!")
println("Hello, Scala!") //这行代码并不会被执行.
}
}
相关推荐
阿里云大数据AI技术20 小时前
StarRocks 助力数禾科技构建实时数仓:从数据孤岛到智能决策
大数据
Lx3521 天前
Hadoop数据处理优化:减少Shuffle阶段的性能损耗
大数据·hadoop
武子康1 天前
大数据-99 Spark Streaming 数据源全面总结:原理、应用 文件流、Socket、RDD队列流
大数据·后端·spark
阿里云大数据AI技术2 天前
大数据公有云市场第一,阿里云占比47%!
大数据
Lx3522 天前
Hadoop容错机制深度解析:保障作业稳定运行
大数据·hadoop
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法
echoarts2 天前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Aomnitrix2 天前
知识管理新范式——cpolar+Wiki.js打造企业级分布式知识库
开发语言·javascript·分布式
每天回答3个问题2 天前
UE5C++编译遇到MSB3073
开发语言·c++·ue5
计算机毕业设计木哥2 天前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计