温习以前学习笔记,总结以前所学。
正则表达式:用于操作字符串的规则,其使用了特殊的符号来表示。个人认为减少代码量。
预定义字符类
/*
预定义字符类
. 任何字符(与行结束符可能匹配也可能不匹配)
\d 数字:[0-9]
\D 非数字: [^0-9]
\s 空白字符:[ \t\n\x0B\f\r]
\S 非空白字符:[^\s]
\w 单词字符:[a-zA-Z_0-9] // _是下划线
\W 非单词字符:[^\w]
注:任何预定义字符没有加上数量词之前仅能匹配一个字符
*/
System.out.println("任意字符:"+"aasd".matches("."));
System.out.println("数字字符:"+"9".matches("\\d"));
System.out.println("非数字字符:"+"@".matches("\\D"));
System.out.println("空白字符:"+"\t".matches("\\s"));
System.out.println("非空白字符:"+"w".matches("\\S"));
System.out.println("单词字符:"+"w".matches("\\w"));
System.out.println("非单词字符:"+"w".matches("\\w"));
Greedy 数量词
/*
Greedy 数量词
X? X,一次或一次也没有
X* X,零次或多次
X+ X,一次或多次
X{n} X,恰好 n 次
X{n,} X,至少 n 次
X{n,m} X,至少 n 次,但是不超过 m 次
*/
System.out.println("?一次或一次也没有 " +"".matches("\\d?"));
System.out.println("*零次或多次 " +"".matches("\\d*"));
System.out.println("+至少出现一次 " +"".matches("\\d+"));
System.out.println("{n}恰好出现n次 " +"012".matches("\\d{3}"));
System.out.println("{n,}至少出现n次 " +"012".matches("\\d{3,}"));
System.out.println("{n,m}至少出现n次,但是不超过 m 次 " +"0123456".matches("\\d{3,9}"));
范围词
/*
范围词
[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](减去)
注:范围词没有加上数量词之前也仅能匹配一个字符
*/
System.out.println("abc".matches("[abc]{3}"));
System.out.println("456".matches("[^abc]{3}"));
System.out.println("¥$".matches("[a-z$¥]*"));
边界匹配器 :
/*
边界匹配器
^ 行的开头
$ 行的结尾
\b 单词边界 只是代表单词的开始或者结束部分,不匹配任何字符
\B 非单词边界
\A 输入的开头
\G 上一个匹配的结尾
\Z 输入的结尾,仅用于最后的结束符(如果有的话)
\z 输入的结尾
*/
public class Demo {
public static void main(String[] args) {
System.out.println("hello world".matches("hello\\b world"));//true
}
}