为了账号安全,请及时绑定邮箱和手机立即绑定

Java基础之正则表达式的构造摘要

标签:
Java

本文是根据JDK_API_1_6_zh_CN编写 ,是其的简化版(阉割版),所选择的内容都是基础性很高的,在熟读此篇后我推荐各位阅读《知道这20个正则表达式 能让你少写1,000行代码》。

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

注意:\d只匹配一个单词字符

Greedy 数量词
X? X,一次或一次也没有
X* X,零次或多次
X+ X,一次或多次
X{n} X,恰好 n 次
X{n,} X,至少 n 次
X{n,m} X,至少 n 次,但是不超过 m 次
数量词修饰预定义字符类;
边界匹配器
^ 行的开头
$ 行的结尾
\b 单词边界
\B 非单词边界
\A 输入的开头
\G 上一个匹配的结尾
\Z 输入的结尾,仅用于最后的结束符(如果有的话)
\z 输入的结尾
字符类
[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](减去)
Logical 运算符
XY X 后跟 Y
X|Y X 或 Y
(X) X,作为捕获组
示例:

package com.string;

import java.util.Scanner;

public class Regularexpression {

    public static void main(String[] args) throws Exception{
        // TODO Auto-generated method stu
        Scanner in=new Scanner(System.in);
        System.out.println("Please input phone number!");
        String str=in.next();
        System.out.println(str.matches("^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\\d{8}$"));//用的是上述推荐文章的正则表达式,真是无用,合着半天什么都没干(我不生产代码,我只是代码的搬运工!哈哈!!!)
            }

}
点击查看更多内容
6人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消