Scala:正则表达式

复制代码
object test03 {
  //正则表达式
  def main(args: Array[String]): Unit = {
    //定义一个正则表达式

    //1.[ab]:表示匹配一个字符,或者是a,或者是b
    //2.[a-z]:表示从a到z的26个字母中的任意一个
    //3.[A-Z]:表示从A到Z的26个字母中的任意一个
    //4.[0-9]:表示从0到9的10个数字中的任意一个
    //4.1[^ab]:表示匹配一个字符,除a,b之外的
    //5.[11]:表示前面的字符能出现11次
//    val reg1="[0-9]{11}".r
//    val reg1="[ab]".r
//    val reg1="a.c".r
//    val reg1="\\d".r
//    val reg1="\\d{3,6}".r  //贪婪模式
//    val reg1="\\d{3,6}?".r  //非贪婪模式
    //6.脱字符 ^ 如果在正则的最前面,表示,要匹配的内容必须在字符串的开头
    //7.脱字符 $ 如果在正则的最后边,表示,要匹配的内容必须在字符串的结尾
    //8.英文的 .:表示除了换行之外的其他的任意一个字符
    //9. \d:表示 0-9 的一个数字
    //10. \D:表示 除了 \d之外 的字符
    //11. \w:表示[a-zAz-Z0-9_] 63个字符中任意一个,”一个字“
    //12. \W:表示 除了 \w之外 的字符
    //13. \s:表示空格
    //14: \S:表示 除了 \s之外 的字符
    //15. 量词
    //15.1 *: 表示 >=0
    //15.2 +: 表示 >=1
    //15.3 ?: 表示 0次或1次
    //15.4 {11}: 表示 恰好11次
    //15.5 {3,5}: 表示 至少3次,最多5次
    //15.6 {3,}: 表示 至少3次,最多不限
    //贪婪模式
    //正则匹配默认是贪婪模式的
    //16. ? 非贪婪模式,加在量词后面
    //在如下字符串中 查找 满足正则表达式要求的内容
//    val str ="i am abc"
    //找到第一个满足条件的
//    val rs=reg1.findFirstIn("i am abc abc")
//    if (!rs.isEmpty){
//      println("找到的是:",rs.get)
//    }
    //找全部的
//    reg1.findAllIn("13612343314").toList.foreach(println)
//    reg1.findAllIn("i am abc abc").toList.foreach(println)
//    reg1.findAllIn("i am abc a!c a!!c").toList.foreach(println)
//    reg1.findAllIn("i am abc a!c a!!c 1 2 3").toList.foreach(println)
//    reg1.findAllIn("136123456781").toList.foreach(println)   //贪婪
//    reg1.findAllIn("136123456781").toList.foreach(println)    //非贪婪

    //正则查找
    //找全部的手机号
    //规则:
    //1.11位数字
    //2.第一个数字是1
    //3.第二个数字是3—9的数
//    val reg1 = "1[3-9]\\d{9}".r
//    reg1.findAllIn("136123456781 and 13838765432 01812345678 1181212345678 are phone numbers").toList.foreach(println)   //正则查找

    //验证: 给定字符串是否符合正则表达式的要求
    //用户名的规则
    //1. 长度在 6-12 位
    //2. 只能以字母开头
    //3. 只能包含如下4种:字母,数字,下划线,#
    val name1="_56!!@@@.com"//不符合
    val name2="abc"//不符合
    val name3="admin123#"
    val reg2="[a-zA-Z][a-zA-Z0-9_#]{5,11}".r
    //matches: 验证字符串是否满足
    println(reg2.matches(name1))
    println(reg2.matches(name2))
    println(reg2.matches(name3))
    println(reg2.matches("a12312313131313131313"))

    //应用:替换
    //要求把手机号的4-7位换成xxx
    //(136) (1234) (5678)
//    val reg1="1[3-9]\\d{9}".r
    val reg1="(1[3-9]\\d)(\\d{3})(\\d{5})".r
    val str="13812345678 and 13987654321 are phone numbers"
    val newStr=reg1.replaceAllIn(str,m=>{
//      println(m.group(1))
//      println(m.group(2))
//      println(m.group(3))
      m.group(1) + "###" + m.group(3)
    })
    println(newStr)
  }
}
相关推荐
小熊美家熊猫系统12 分钟前
社区家政与平台家政:两种创业模式的深度对比分析
大数据·家政行业·社区家政·平台家政·家政管理软件
互联网志13 分钟前
打通转化通道 赋能产业发展——高校科技成果转化的现状与破局
大数据·人工智能·物联网
绿虫光伏运维18 分钟前
一文理清光伏运维的内容、常见问题与重要措施
大数据·运维·光伏业务
秋919 分钟前
OceanBase与GreatSQL在Java应用中的性能调优方法有哪些?
java·开发语言·oceanbase
澈20721 分钟前
C++多态编程:从原理到实战
开发语言·c++
zandy101128 分钟前
HENGSHI SENSE 6.2 架构全景解析:Data Agent、指标引擎与Headless语义层的工程实现
大数据·人工智能·架构
今天又在写代码29 分钟前
并发问题解决
java·开发语言·数据库
聆风吟º30 分钟前
【C标准库】深入理解C语言strcat函数:字符串拼接的利器
c语言·开发语言·strcat·库函数
带娃的IT创业者34 分钟前
深度解析:从零构建高性能 LLM API 中转网关与成本优化实战
开发语言·gpt·llm·php·高性能·成本优化·api网关