正则表达式语法
元字符 | 描述 |
---|---|
\ | 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n"匹配字符"n”。"\n"匹配换行符。序列"\\“匹配”\","\(“匹配”("。 |
^ | 匹配输入字符串的开始位置 |
$ | 匹配输入字符串的结束位置 |
| | 将两个匹配条件进行逻辑“或”(Or)运算。例如正则表达式(him| he匹配"it belongs to him"和"it belongs to her",但是不能匹配"it belongs to them."。 |
+ | 匹配1或多个正好在它之前的那个字符。例如正则表达式9+匹配9、99、999等。 |
* | 匹配前面的子表达式任意次 |
? | 匹配0或1个正好在它之前的那个字符。 |
. | 匹配除“\n”之外的任何单个字符。 |
{n} | n 是非负整数。正好匹配 n 次。例如,“o{2}”与“Bob”中的“o”不匹配,但与“food”中的两个“o”匹配。 |
{n,m} | n 和 m 是非负整数,其中 n <= m。匹配至少 n 次,至多 m 次。例如,“o{1,3}”匹配“fooooood”中的头三个 o。‘o{0,1}’ 等效于 ‘o?’。注意:您不能将空格插入逗号和数字之间。 |
[xyz] | 字符集合。匹配所包含的任意一个字符。例如,“[abc]”可以匹配“plain”中的“a”。 |
[^xyz] | 负值字符集合。匹配未包含的任意字符。例如,“[^abc]”可以匹配“plain”中的“plin”。 |
[a-z] | 字符范围。匹配指定范围内的任意字符。例如,“[a-z]”可以匹配“a”到“z”范围内的任意小写字母字符。 |
[^a-z] | 负值字符范围。匹配任何不在指定范围内的任意字符。例如,“[^a-z]”可以匹配任何不在“a”到“z”范围内的任意字符。 |
\d | 数字字符匹配。等效于 [0-9]。 |
\D | 非数字字符匹配。等效于 [^0-9]。 |
\f | 换页符匹配。等效于 \x0c 和 \cL。 |
\n | 换行符匹配。等效于 \x0a 和 \cJ。 |
\r | 匹配一个回车符。等效于 \x0d 和 \cM。 |
\s | 匹配任何空白字符,包括空格、制表符、换页符等。与 [ \f\n\r\t\v] 等效。 |
\n | 换行符匹配。等效于 \x0a 和 \cJ。 |
正则表达式例子
例一:字符串的分割
public class ex1 {
public static void main(String[] args) {
String str = "abc;123,456?999|haha";
String[] strs=str.split(";|,");//匹配";"或",",多个分隔符用 " | " 分开
for(String s : strs) {
System.out.println(s);
}
System.out.println("");
String[] strs2=str.split("[;,?|25]");//字符集。匹配包含的任一字符,用中括号括起来
for(String s:strs2) {
System.out.println(s);
}
}
}
例二:在字符串中查找是否存在子字符串
import java.util.regex.*;
public class ex2 {
public static void main(String[] args) {
// 用正则表达式查找字符串中是否包含HZNU
String str1="I am from HZNU!";
String str2=".*HZNU.*";
boolean isMatch=Pattern.matches(str2, str1);
System.out.println("字符串 "+str1+" 里是否包含HZNU");
System.out.println(isMatch);
}
}
例三:检查qq号是否合法
import java.util.Scanner;
public class ex3 {
public static void main(String[] args) {
// 检查qq号是否合法
String qq;
System.out.print("请输入qq号: ");
Scanner scanner = new Scanner(System.in);
qq = scanner.next();
String reg = "[1-9][0-9]{4,14}";//qq号码由非0开头的5~15位纯数字组成
System.out.println(qq.matches(reg)?"合法qq":"非法qq");
}
}