正则表达式:
(1)对一些字符进行匹配、查找、替换等复杂的操作,需要通过正则表达式实现这些操作
(2)是一个有“特殊意义”的字符串,定义了一种“校验规则”
常用字符集:
[]:表示匹配括号内的一个字符
[abc]:表示匹配abc中的任意一个
[a-z]:表示匹配a-z中的任意一个字符
[0-9]:表示匹配0-9中的任意一个字符
[a-zA-Z0-9]:表示匹配这些字符中的任意一个字符
[^a]:表示匹配除了a字符的任意一个字符
[a-z&&[^a]]:表示a-z除了a的任意一个字符
预定义字符集:
.:表示匹配任意一个字符
\d:表示匹配任意一个数字字符,相当于[0-9]
\w:表示匹配任意一个单词字符,相当于[a-zA-Z0-9_]
\s:表示匹配任意一个空格字符,相当于[\t\r\n\b]
\D:表示匹配任意一个非数字字符,相当于[^0-9]
\W:表示匹配任意一个非单词字符,相当于[^a-zA-Z0-9_]
\S:表示匹配任意一个非空格字符,相当于[^\t\r\n\d]
一些特殊字符需要使用转义字符:"\"
数量词:
X:表示字符集
X?:匹配X 0个或1个
X+:匹配X 1个或1个以上
X*:匹配X 0个或0个以上
X{m}:匹配X m个
X{m,}:匹配X m个或m个以上
X{m,n}:匹配X m到n个
():分组:
()将正则表达式的部分规则进行划分,可以使用|来进行选择其中一组规则
reg:
+86 13258888149
0086 13258888149
正则表达式:(+86|0086)?\\s?1\\d{10}
^和$:
当校验字符串是不是从头到尾都符合一个规则校验,需要在正则表达式前后添加相应的符号
^:添加在正则表达式前,表示要校验的普通字符串的开头必须符合规则
$:添加在正则表达式后,表示要校验的普通字符串的末尾必须符合规则
^和$同时存在,考虑普通字符串的整体
reg:
"^[\\d]{6,8}" "123456abc" 满足规则
"[\\d]{6,8}$" "abc123456" 满足规则
"^[\\d]{6,8}$" "123456" 满足规则
matchs(String regex):此方法验证不了自定义时添加的^或$,因为当把正则表达式传入方法内后,内部逻辑帮助添加了^和$
总结:
正则表达式是一个灵活,逻辑性强的规则校验语法,通常用于文本中