常用字符集
[]:表示匹配括号内的一个字符
[abc]:表示匹配abc中的任意一个 字符
[a-z]:表示匹配a-z中的任意一个字符
[0-9]:表示匹配0-9中的任意一个字符
[a-zA-Z0-9]:表示匹配这些字符中的任意一个字符
[^a]:表示匹配除了a字符的任意一个字符
[a-z&&[^a]]:表示匹配a-z中除了a的任意一个字符
预定义字符集
. :表示匹配任意一个字符
\b:表示匹配任意一个单词边界;
\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\b]
一些特殊字符需要使用转义字符: "\"
数量词:
X:表示字符集
X?:匹配X 0个或1个
X+:匹配X 1个或1个以上
X*: 匹配X 0个或0个以上
X{m}: 匹配X m个
X{m,}:匹配X m个以上
X{m,n}:匹配X m到n个
():分组
()将正则表达式的部分规则进行了划分,可以使用|来进
行选择其中一组规则
reg:手机号前带有区号
+861375651674
0086 1375651674
正则表达式:
(+86|0086)?\\s?1\\d{10}
判断一个字符串是不是一个网址
http://www.baidu.com
https://www.baidu.com
www.baidu.com
www.baidu.cn
www.baidu.com.cn
www.baidu.net
www.baidu.edu
^和$
有时,我们想校验一个字符串是不是从头到尾都符合一个规则校验
此时需要在正则表达式前后添加相应的符号:
^:添加在正则表达式前,表示要校验的普通字符串的开头就
必须符合规则
$:添加在正则表达式后,表示要校验的普通字符串的末尾
必须符合规则
前后都有此符号时:考虑的普通字符串的整体