正则表达式基本语法(快速认知)

正则表达式:一种用于匹配字符串的模式。它可以用于搜索、替换、验证字符串等多种操作。

基本语法:

  1. 字符类:

    • [abc]: 匹配 ab 或 c
    • [a-z]: 匹配小写字母。
    • [A-Z]: 匹配大写字母。
    • [0-9]: 匹配数字母

 

比如我们的电话号码是11个数字组成, 则可以表示为:

String tel="[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]"表示11个0到9之间的数字,String中有matches方法,可以用于匹配正则表达式,正确返回true;

public class Main {
    public static void main(String[] args) {
        String tel="[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]";
        String num="19960991491";
        if (num.matches(tel)) {
            System.out.println("true");
        }
    }

}

结果:true;


Java还提供了一系列预定义的符号,用于简化字符类的书写:

  • .: 匹配任意单个字符(除了换行符)。
  • \d: 匹配数字,等价于 [0-9]
  • \D: 匹配非数字字符,等价于 [^0-9]
  • \w: 匹配字母数字字符,等价于 [a-zA-Z0-9_]
  • \W: 匹配非字母数字字符,等价于 [^a-zA-Z0-9_]
  • \s: 匹配空白字符(空格、制表符、换行符等)。
  • \S: 匹配非空白字符。

 比如之前的电话号码也可简化为:

String tel="\\d\\d\\d\\d\\d\\d\\d\\d\\d\\d\\d";//第一个\表示转义字符随后跟一个\d

 电话号码这样写\\d\\d\\d\\d\\d\\d\\d\\d\\d\\d\\d会不会感觉很复杂,很多重复的数字,于是有了量词

    • *: 匹配前面的表达式零次或多次。
    • +: 匹配前面的表达式一次或多次。
    • ?: 匹配前面的表达式零次或一次。
    • {n}: 匹配前面的表达式恰好 n 次。
    • {n,}: 匹配前面的表达式至少 n 次。
    • {n,m}: 匹配前面的表达式至少 n 次,但不超过 m 次。

比如上面的电话号码还能改进为:

 String tel="\\d{11}";表示11个数字;


还有一些是反义字符,^表示非,除此之外的意思


分组括号

这个情况,大家应该都遇见过,他是怎么匹配的呢这就可以使用分组括号

 

它就可以写为:([A-Z0-9]{5}-){4}[A-Z0-9]{5}//用一个括号将一组元素表示出来,再用量词{n}表示匹配该组元素多少次,最后再加上最后一组元素

字符串中常用含有正则表达式的方法:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值