Scala的正则表达式(2)

复制代码
package hfd
//任务:把字符串中的手机号打码  类似于:138****5678
//正则表达式的应用场景
//查找,验证,替换
object Test36_1 {
  def main(args: Array[String]): Unit = {
   val str= "张先生,手机号:13812345678 13612345454  寝室号:1345-01 你买的 xxx 到了 "
    //开始你的代码
    //138    1234  5678

    //()是分组,它不会影响正则表达式的查询结果,但是,它会把分组找到的内容单独保存在group中
    val reg="(1[3-9]\\d)(\\d{4})(\\d{4})".r
    //reg.replaceAllIn的功能:在目标字符串str中,用正则表达式reg去查找,找到之后,用箭头函数的返回值
    //来替换.

    //m 就是正则表达式找到内容
    //如果正则表达式中有(),则可以通过m.group来找到对应的分组
    val newStr=reg.replaceAllIn(str,(m)=> {
      println(s"第一组:${m.group(1)}")
      println(s"第二组:${m.group(2)}")
      println(s"第三组:${m.group(3)}")
      println(s"-" * 40)
      m.group(1) + "****" + m.group(3)
    })
    println(newStr)

    "张先生,手机号:138****5678 你买的 xxx 到了 "
  }

}
相关推荐
孤岛奇兵常凯申12 小时前
Scala中的高阶函数(一)
scala
盛小夏1 天前
用 Python 把汉诺塔玩成“魔法”:从递归到可视化,一篇就够!
scala
智海观潮4 天前
学好Spark必须要掌握的Scala技术点
大数据·spark·scala
盛小夏5 天前
用链式风格写代码,就像在搭积木
scala
盛小夏8 天前
元组(Tuple)详解:初学者必须掌握的数据结构
scala
赞鱼儿8 天前
Scala中函数的基本使用
scala
还是大剑师兰特9 天前
Scala面试题及详细答案100道(71-80)-- 与Java的交互
scala·大剑师·scala面试题
927410 天前
12函数参数
scala
geilip15 天前
知识体系_scala_利用scala和spark构建数据应用
开发语言·spark·scala
Hello.Reader15 天前
Flink 高级配置发行版剖析、Scala 版本、Table 依赖与 Hadoop 集成实战
hadoop·flink·scala