JAVA小练习130——正则的规则

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_]+"));
	
	
		
	}

}

猜你喜欢

转载自blog.csdn.net/Eric_The_Red/article/details/91834376
今日推荐