用Java实现正则表达式

it2023-05-04  75

正则表达式语法

元字符描述\将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“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"); } }
最新回复(0)