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 到了 "
  }

}
相关推荐
linweidong15 天前
一站式用AI编程神奇Cursor/Trae(VScode环境)开发运行Scala应用
大数据·vscode·后端·大模型·scala·ai编程·cursor
白总Server23 天前
GaussDB 分布式数据库调优(架构到全链路优化)
java·网络·c++·架构·go·scala·数据库架构
小伍_Five24 天前
spark数据处理练习题番外篇【下】
java·大数据·spark·scala
无人赴约的cat1 个月前
【20250607接单】Spark + Scala + IntelliJ 项目的开发环境配置从零教学
大数据·spark·scala
小伍_Five1 个月前
spark数据处理练习题番外篇【上】
java·大数据·spark·scala
渣渣盟1 个月前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
zhojiew1 个月前
关于akka官方quickstart示例程序(scala)的记录
后端·scala
小伍_Five1 个月前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超1 个月前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server1 个月前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala