java正则表达式:

几个基本知识:

  1. 基本语法:

注意开头与结尾。

“^”匹配输入字符串开始的位置。如果设置了 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有一个奇怪的特性,就是经常编译的时候加一个“/”会出现编译不通过的情况。这个时候加两个“//”就可以解决这个问题。