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

}
相关推荐
是阿威啊5 天前
【用户行为归因分析项目】- 【企业级项目开发第五站】数据采集并加载到hive表
大数据·数据仓库·hive·hadoop·spark·scala
是阿威啊8 天前
【用户行为归因分析项目】- 【企业级项目开发第四站】模拟三类用户行为数据上传到Hadoop
大数据·hadoop·分布式·sql·scala
今天没有盐10 天前
Python字符串操作全解析:从基础定义到高级格式化
后端·scala·编程语言
是阿威啊11 天前
【用户行为归因分析项目】- 【企业级项目开发第一站】项目架构和需求设计
大数据·hive·hadoop·架构·spark·scala
代码于老总13 天前
【Scala 技巧】用隐式类给 String “开挂”:一行代码实现手机号 / 身份证号校验
scala
scala舔狗汪13 天前
scala的隐式对象和隐式类
scala
是阿威啊14 天前
【maap-analysis】spark离线数仓项目完整的开发流程
大数据·分布式·spark·scala
豚踢兔x19 天前
正则表达式应用-手机号打码
scala
代码于老总20 天前
正则表达式在 Scala 中的应用
scala
凯新生物1 个月前
聚乙二醇二生物素,Biotin-PEG-Biotin在生物检测中的应用
scala·bash·laravel·perl