常用字符集
[]:表示匹配括号内的一个字符
[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个
():分组, ()将正则表达式的部分规则进行了划分,可以使用|来进行选择其中一组规则
例如:判断一个字符串是不是一个网址
http://www.baidu.com
https://www.baidu.com
www.baidu.com
www.baidu.cn
www.baidu.com.cn
www.baidu.net
www.baidu.edu
String regex="(http://|https://)?www.baidu\\.(com|cn|com\\.cn|\\.net\\.edu){1}"
^和$
^:添加在正则表达式前,表示要校验的普通字符串的开头就 必须符合规则
$:添加在正则表达式后,表示要校验的普通字符串的末尾 必须符合规则
ps:前后都有此符号时:考虑的普通字符串的整体
常用的正则表达式:
// 由数字和字母组成的内容,可以混合
String regex = "(\\d|[a-zA-Z])+";
// 要么全是字母要么全是数字(1个正则表达式)
String regex = "(\\d+|[a-zA-Z]+){1}";