正则表达式
字符匹配
- 普通字符:普通字符按照字面意义进行匹配,例如匹配字母 “a” 将匹配到文本中的 “a” 字符。
- 元字符:元字符具有特殊的含义,例如
\d 匹配任意数字字符,\w 匹配任意字母数字字符,. 匹配任意字符(除了换行符)等。
量词
*:匹配前面的模式零次或多次。
+:匹配前面的模式一次或多次。
?:匹配前面的模式零次或一次。
{n}:匹配前面的模式恰好 n 次。
{n,}:匹配前面的模式至少 n 次。
{n,m}:匹配前面的模式至少 n 次且不超过 m 次。
字符类
[ ]:匹配括号内的任意一个字符。例如,[abc] 匹配字符 “a”、”b” 或 “c”。
[^ ]:匹配除了括号内的字符以外的任意一个字符。例如,[^abc] 匹配除了字符 “a”、”b” 或 “c” 以外的任意字符。
边界匹配
^:匹配字符串的开头。
$:匹配字符串的结尾。
\b:匹配单词边界。\bab\b匹配ab开头和结尾单词,… ab ….
\B:匹配非单词边界。\Bab\B 上面的其他情况
分组和捕获
( ):用于分组和捕获子表达式。([0-255]\.){3}[0-255]匹配ip地址
(?: ):用于分组但不捕获子表达式。
特殊字符
\:转义字符,用于匹配特殊字符本身。\s空白,\n,\r回车
.:匹配任意字符(除了换行符)。
|:用于指定多个模式的选择。