java正则表达式:
几个基本知识:
- 基本语法:
注意开头与结尾。
“^”匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,“^”还会与"\n"或"\r"之后的位置匹配。
“$”匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,“$”还会与"\n"或"\r"之前的位置匹配。
字符的重复。
+代表,至少出现一次,最多不限。
*代表可以出现多次或零次。
“?”当此字符紧随任何其他限定符(*、+、?、{n}、{n,}、{n,m})之后时,匹配模式是"非贪心的"。"非贪心的"模式匹配搜索到的、尽可能短的字符串,而默认的"贪心的"模式匹配搜索到的、尽可能长的字符串。此外,代表先前括号里的字符串出现一次或者不出现。
{n}n 是非负整数。正好匹配 n 次。
{n,}n 是非负整数。至少匹配 n 次。
{n,m}m 和 n 是非负整数,其中 n <= m。匹配至少 n 次,至多 m 次。
字符集。
[xyz]字符集。匹配包含的任一字符。
[^xyz]反向字符集。匹配未包含的任何字符。
[a-z]字符范围。匹配指定范围内的任何字符。
[^a-z]反向范围字符。匹配不在指定的范围内的任何字符。
2.捕获组
捕获组是把多个字符当一个单独单元进行处理的方法,它通过对括号内的字符分组来创建。
注意这个组,是按照括号的数量一一匹配的,也就是说有几个括号,就有几个组。
但是有一个统一的group(0)代表整个正则表达式。
3.几个注意点
“/”意为着转义。代表的是与平常不同的意思,也就是说平常是什么意思,转义后就不是这个意思。“.”平常代表的是匹配任意字符,那么“/.”就代表着匹配普通的“.”。
但是java有一个奇怪的特性,就是经常编译的时候加一个“/”会出现编译不通过的情况。这个时候加两个“//”就可以解决这个问题。