public class Demo130 {
public static void main(String[] args) {
/*
预定义字符类
. 任何字符(与行结束符可能匹配也可能不匹配)
\d 数字:[0-9]
\D 非数字: [^0-9]
\s 空白字符:[ \t\n\x0B\f\r]
\S 非空白字符:[^\s]
\w 单词字符:[a-zA-Z_0-9] a-z A-Z 0-9 _
\W 非单词字符:[^\w]
注意: 一个预定于字符只能匹配一个字符,除非预定义字符串配合了数量词使用。
*/
System.out.println(". 任何字符:"+("%".matches(".")));
System.out.println("\\d代表了数字:"+("a".matches("\\d")));
System.out.println("\\D代表了非数字:"+("@".matches("\\D")));
System.out.println("\\s代表了空白字符:"+("\n".matches("\\s")));
System.out.println("\\S代表了非空白字符:"+("a".matches("\\S")));
System.out.println("\\w代表了单词字符:"+("_".matches("\\w")));
System.out.println("\\W代表了非单词字符:"+("a".matches("\\W")));
/*数量词:
X? X,一次或一次也没有
X* X,零次或多次
X+ X,一次或多次
X{n} X,恰好 n 次
X{n,} X,至少 n 次
X{n,m} X,至少 n 次,但是不超过 m 次 */
System.out.println("?一次或一次也没有:"+ ("12".matches("\\d?")));
System.out.println("* 零次或多次:"+ ("12".matches("\\d*")));
System.out.println("+ 至少一次:"+ ("12".matches("\\d+")));
System.out.println("{n} 恰好n次:"+ ("121".matches("\\d{3}")));
System.out.println("{n,} 至少出现n次:"+ ("121".matches("\\d{3,}")));
System.out.println("{n,m} 至少出现 n~ m次 :"+ ("1212111".matches("\\d{3,6}")));
/*
范围词:
[abc] a、b 或 c(简单类)
[^abc] 任何字符,除了 a、b 或 c(否定)
[a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围)
注意:一个范围词没有配合数量词使用也只能匹配一个字符而已。
*/
System.out.println("d".matches("[abc]+"));
System.out.println("abc".matches("[^abc]+"));
System.out.println("123456_".matches("[a-zA-Z0-9_]+"));
}
}
JAVA小练习130——正则的规则
最新推荐文章于 2024-04-19 12:16:31 发布