正则表达式,主要是用来精确匹配字符串的。
基本语法
正则表达式的形式一般如下:
/love/ 其中位于“/”定界符之间的部分就是将要在目标对象中进行匹配的模式。用户只要把希望查找匹配对象的模式内容放入“/”定界符之间即可。为了能够使用户更加灵活的定制模式内容,正则表达式提供了专门的“元字符”。所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符)在目标对象中的出现模式。
较为常用的元字符包括: “+”, “*”,以及 “?”。
“+”元字符规定其前导字符必须在目标对象中连续出现一次或多次。
“*”元字符规定其前导字符必须在目标对象中出现零次或连续多次。
“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次
正则表达式使用特殊符号。我将各种符号以及其意义和用法简单的介绍一下:
^ 和输入的开始一致。
$ 以它前面的字符结尾的;例如:ab+$就可以被“abb”,“ab”匹配;
* 与此符号之前的文字0次以上相同的话,两者一致。例:"zo*"和"zoo","z"都一致。
+ 与此符号之前的文字1次以上相同的话,两者一致。例:"zo+"和"zoo"一致,但和"z"不一致。
? 与此符号之前的文字0次或1次相同的话,两者一致。例:"a?ve?"和"never"的"ve"一致。
. 为通配符,表示任何一个字符,例如:“a.c”可以匹配“anc”、“abc”、“acc”;(与除了换行符的所有单一文字一致。)
| 或运算符,例如:a(n|bc|cb)c可以匹配“abcc”,“anc”,“acbc”;
在正则表达式中实现类似编程逻辑中的“或”运算,在多个不同的模式中任选一个进行匹配的话,可以使用管道符 “|”。例如:to|too|2 上述正则表达式将会与目标对象中的 “to”, “too”, 或 “2” 相匹配
(正则表达式) 以所指定的表达式寻找一致文字。如果找到了,储存下来。一致的部分可以从Match方法获得的阵列中找到。 可以在正则表达式中使用 “()” 把字符串组合在一起。“()”符号包含的内容必须同时出现在目标对象中。
x|y x和y的任意一方相同都会被认为一致。例:"(z|f)ood"和"zood","food"都一致。
{n} n是0以上的整数。与其前的文字n次相同的话,两者一致。例:"o{2}"和"Bob"中的"o"不一致,与"foooood"中的前两个"o"一致。
{n,} n是0以上的整数。与其之前的文字至少n次相同才一致。
{,n} n是0以上的整数。匹配n到无穷次之间任意次数。
{n,m} 两者整数。n至m范围的次数一致。
[xyz] 与中括号中的文字任意一个相同都被认为一致。
[^xyz] 与上面的相反。
[a-z] 文字的范围,从"a"到"z"的文字都被认为一致。
[^a-z] 与上面的相反。
[] 在[]内可以指定要求匹配的字符,例如:"a[nbc]c"可以匹配"anc"、"abc"、"acc";但不可以匹配"ancc",a到z可以写成[a-z],0到9可以写成[0-9];
例如:
电话号码:024-84820482,02484820482(假设前面3或者4位,后面7或者8位,并且中间的减号可有可无)
都是符合规定的,那么可以用如下格式来匹配:[0-9]{3,4} \-? [0-9]{7,8};
-注意:“\”为转义字符,因为“-”在正则表达式用有代表一个范围的意义,例如:前面所说的[0-9],
所以它需要转义字符“\”进行转义才可使用;
\b 表示单词的末尾。例:"er\b"和"never"的"er"一致,但和"verb"的"er"不一致。
\B 表示非单词的末尾。
\d 表示数字。
\D 表示非数字。
\s 表示空格。
\S 表示非空格。
\w 表示所有字母数字。
\W 表示非所有字母数字。
\d表示[0-9];\D表示[^0-9];\w表示[A-Z0-9];\W表示[^A-Z0-9];\s表示[\t\n\r\f],就是空格字符包括tab,空格等等;\S表示[^\t\n\r\f],就是非空格字符
i (忽略大小写) /* 注意点 */
g (全文查找出现的所有 pattern) /* 注意点 */
gi (全文查找、忽略大小写)/* 注意点 */
\num num应该被赋予一个正数。与已经储存的部分比较。例:"(.)\1"和任意的两个连续的相同
文字一致。
了解了这些之后看下面的注意点:
String s1="111+222+333";
System.out.println(s1.split("+").length);
//输出时提示错误:
java.util.regex.PatternSyntaxException: Dangling meta character '+' near index
问题出现在加号附近,查询相关的资料显示,+、*、|、\等符号在正则表达示中有相应的不同意义。
需要这样:
String s1="111+222+333";
System.out.println(s1.split("[+]").length);
或是
String s1="111+222+333";
System.out.println(s1.split(" \\+").length);// 符号“\”本身就是特殊符号 :转义符,因此是两个 "\"即“\\”表示符号 \
如果除了上面匹配的所有单词之外,你还想要匹配“toon”,那么,你可以使用“|”操作符。“|”操作符的基本意义就是“或”运算。要匹配“toon”,使用“t(a|e|i|o|oo)n”正则表达式。这里不能使用方扩号,因为方括号只允许匹配单个字符;这里必须使用圆括号“()”。圆括号还可以用来分组,具体请参见后面介绍。
.(点号)字符意即'任一字符'。因此,a.c匹配于abc、aac以及aqc。单个点号用以表示自己的情况很少,它多半与其他meta字符搭配使用,这一结合允许匹配多个字符,这部分稍后会提及。
最后一种匹配单个字符的方式是使用方括号表达式(bracket expression)。最简单的方括号表达式是直接将字符列表放在方括号里,例如,[aeiouy]表示的就是所有小写元音字母。举例来说,c[aeiouy]t匹配于cat、cot以及cut(还有cet、cit,与cyt),但不匹配于cbt。
匹配含字符串 hello、world、中国 字符串的正则表达式:
[\s\S]*?(hello)|(world)|(中国)[\s\S]*?