正则表达式——(1) 概述、常见规则

目录

 

一、概念

二、常见的正则规则

1、一次或一次也没有

2、X 至少出现n此,但是不超过m次


一、概念

   总结为:正确的规则匹配

正则表达式用来操作字符串数据

二、应用需求

   校验QQ号:定义一个功能对QQ号进行校验,长度5~15,只能是数字,0不能开头。

纯Java代码编写:

public static void chekeQQ(String qq) {
        int len = qq.length();
        if (len >= 5 && len <= 15) {
            if (!qq.startsWith("0")) {
                try {
                    long l = Long.parseLong(qq);
                    System.out.println(l + ":正确");
                } catch (NumberFormatException e) {
                    System.out.println(qq + ":含有非法字符");
                }
            } else {
                System.out.println(qq + ":不能0开头");
            }
        } else {
            System.out.println(qq + ":长度错误");
        }
    }

测试:

 public static void main(String[] args) {
        String qq = "01234567";
        chekeQQ(qq);
    }

  

使用正则表达式:

分析第一位不能使用0,第二位是0-9,整体长度是5-15。接下来编写正则

[1-9][0-9]{4,14}

 编写代码并测试:

public static void main(String[] args) {
        String qq = "01234567";
        //正则表达式规则
        String rege="[1-9][0-9]{4,14}";
        //使用字符串的matches方法
        boolean b = qq.matches(rege);
        System.out.println(qq+":"+b);
    }

  

 

二、常见的正则规则

在API中有java.util.regex.Pattern类,Pattern类描述了一些正则规则和常用的方法。

字符类
[abc]a、b 或 c(简单类)
[^abc]任何字符,除了 a、b 或 c(否定)
[a-zA-Z]a 到 z 或 A 到 Z,两头的字母包括在内(范围)
[a-d[m-p]]a 到 d 或 m 到 p:[a-dm-p](并集)
[a-z&&[def]]d、e 或 f(交集)
[a-z&&[^bc]]a 到 z,除了 b 和 c:[ad-z](减去)
[a-z&&[^m-p]]a 到 z,而非 m 到 p:[a-lq-z](减去)

 

预定义字符类
.任何字符(与行结束符可能匹配也可能不匹配)
\d数字:[0-9]
\D非数字: [^0-9]
\s空白字符:[ \t\n\x0B\f\r]
\S非空白字符:[^\s]
\w单词字符:[a-zA-Z_0-9]
\W非单词字符:[^\w]

边界匹配器
^行的开头
$行的结尾
\b单词边界
\B非单词边界
\A输入的开头
\G上一个匹配的结尾
\Z输入的结尾,仅用于最后的结束符(如果有的话)
\z输入的结尾

Greedy 数量词
X?X,一次或一次也没有
X*X,零次或多次
X+X,一次或多次
X{n}X,恰好 n
X{n,}X,至少 n
X{n,m}X,至少 n 次,但是不超过 m

 在我们的QQ验证中就用到了数量次数X{n,m}。

现在以数量词为示例演示一些正则规则

1、一次或一次也没有

X?X,一次或一次也没有

单词 "o" 在str中只能出现一次。

        String str="aob";
        String pattern="ao?b";
        boolean matches = str.matches(pattern);
        System.out.println(str+":"+matches);

  

 String str="aoooob";
        String pattern="ao?b";
        boolean matches = str.matches(pattern);
        System.out.println(str+":"+matches);

  

2、X 至少出现n此,但是不超过m次

X{n,m}X,至少 n 次,但是不超过 m
String str="aoooob";
        String pattern="ao{2,4}b";
        boolean matches = str.matches(pattern);
        System.out.println(str+":"+matches);

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

真香号

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值