ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
Pattern类 静态方法compile获取Pattern对象 ```java Pattern pattern = Pattern.compile("正则表达式"); ``` pattern方法获取被编译后的正则表达式 ```java Pattern pattern = Pattern.compile("正则表达式"); String string = pattern.pattern(); ``` 静态方法matches校验给定串是否匹配给定正则表达式 ```java boolean matches = Pattern.matches("[a-z]", "a"); ``` split方法根据给定正则表达式分割给定串 ```java Pattern pattern = Pattern.compile(","); String[] split = pattern.split("a,b,c,d,e,f,g"); ``` matcher方法获取一个匹配器 ```java Pattern pattern = Pattern.compile("\\."); Matcher matcher = pattern.matcher("a.b.c"); ``` ### 分组 > 通过从左至右计算其开括号来编号 ( (A) (B (C) ) ) 分组0:`( (A) (B (C) ) )`[默认分组(特殊的组)]总是代表整个表达式 分组1:`( (A) (B (C) ) )` 分组2:`(A)` 分组3:` (B (C) )` 分组4:`(C)` ```java Matcher matcher = pattern.matcher("a.b.c"); matcher.groupCount() // 获取分组的数量 ``` ### 正则表达式语法 | 字符 | 说明 | | :--: | :--------------------------: | | \ | 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。 | 例如:普通的`"n"`只会匹配到字符`"n"`,但是加了`\`字符后,`\n`表示匹配换行符。 在Java的String串中,`\`表示转移,所以想表达出正则表达式中的`\`,需要用两个`\`才行,比如:`\\`表示一个`\`符号。想要表示一个普通的反斜杠需要用`\\\\`,原因是,`\\`表示一个`\`,两个`\\`表示一个`\\`,而`\\`在正则表达式中表示一个`\`符号。 | 字符 | 说明 | | :--: | :-----------: | | ^ | 匹配输入字符串开始的位置。 | | $ | 匹配输入字符串结尾的位置。 | 如果设置了 **RegExp** 对象的 **Multiline** 属性, ^ 和 $ 还会与"\n"或"\r"之前的位置匹配。 | 字符 | 说明 | | :--: | :---------------------------: | | * | 零次或多次匹配前面的字符或子表达式。 等效于 {0,}。 | | + | 一次或多次匹配前面的字符或子表达式。 等效于 {1,}。 | | ? | 零次或一次匹配前面的字符或子表达式。 等效于 {0,1}。 | | 字符 | 说明 | | :-------: | :------------------: | | {*n*} | 正好匹配 *n* 次。 | | {*n*,} | 至少匹配 *n *次。 | | {*n*,*m*} | 匹配至少 *n* 次,至多 *m* 次。 | | 字符 | 说明 | | :--: | :--------------------------------------: | | ? | 当此字符紧随任何其他限定符(*、+、?、{*n*}、{*n*,}、{*n*,*m*})之后时,匹配模式是"非贪心的"。 | "非贪心的"模式匹配搜索到的、尽可能短的字符串,而默认的"贪心的"模式匹配搜索到的、尽可能长的字符串。例如,在字符串"oooo"中,"o+?"只匹配单个"o",而"o+"匹配所有"o"。 | 字符 | 说明 | | :--: | :-----------------: | | . | 匹配除"\r\n"之外的任何单个字符。 | 若要匹配包括"\r\n"在内的任意字符,请使用诸如"[\s\S]"之类的模式。 | 字符 | 说明 | | :---------: | :-----------------------: | | (*pattern*) | 匹配 *pattern* 并捕获该匹配的子表达式。 | 可以使用 \$0…\$9 属性从结果"匹配"集合中检索捕获的匹配。若要匹配括号字符 ( ),请使用"\\("或者"\\)"。 | 字符 | 说明 | | :-----------: | :------------------------------------: | | (?:*pattern*) | 匹配 *pattern* 但不捕获该匹配的子表达式,不存储供以后使用的匹配。 | 这对于用"or"字符 (|) 组合模式部件的情况很有用。例如,'industr(?:y|ies) 是比 'industry|industries' 更经济的表达式。 | 字符 | 说明 | | :-----------: | :--------------------------------------: | | (?=*pattern*) | 执行正向预测先行搜索的子表达式,表达式处于匹配 *pattern* 的字符串的起始点的字符串。 | 它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,'Windows (?=95|98|NT|2000)' 匹配"Windows 2000"中的"Windows",但不匹配"Windows 3.1"中的"Windows"。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。 | 字符 | 说明 | | :-----------: | :--------------------------------: | | (?!*pattern*) | 执行反向预测先行搜索的子表达式。与(?=*pattern*)做对比。 | 它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,'Windows (?!95|98|NT|2000)' 匹配"Windows 3.1"中的 "Windows",但不匹配"Windows 2000"中的"Windows"。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。 | 字符 | 说明 | | :------: | :-----------: | | *x*\|*y* | 匹配 *x* 或 *y*。 | 例如,'z|food' 匹配"z"或"food"。'(z|f)ood' 匹配"zood"或"food"。 | 字符 | 说明 | | :-----: | :--: | | [*xyz*] | 字符集。 | 匹配包含的任一字符。例如,"[abc]"匹配"plain"中的"a"。 | 字符 | 说明 | | :------: | :----: | | [^*xyz*] | 反向字符集。 | 匹配未包含的任何字符。 | 字符 | 说明 | | :-----: | :---: | | [*a-z*] | 字符范围。 | 匹配指定范围内的任何字符。例如,"[a-z]"匹配"a"到"z"范围内的任何小写字母。 | 字符 | 说明 | | :------: | :-----: | | [^*a-z*] | 反向字符范围。 | 匹配不在指定的范围内的任何字符。 | 字符 | 说明 | | :--: | :----------------: | | \b | 匹配一个字边界,即字与空格间的位置。 | 例如,"er\b"匹配"never"中的"er",但不匹配"verb"中的"er"。 | 字符 | 说明 | | :--: | :-----: | | \B | 非字边界匹配。 | "er\B"匹配"verb"中的"er",但不匹配"never"中的"er"。 | 字符 | 说明 | | :---: | :-------------: | | \c*x* | 匹配 *x* 指示的控制字符。 | 例如,\cM 匹配 Control-M 或回车符。*x* 的值必须在 A-Z 或 a-z 之间。如果不是这样,则假定 c 就是"c"字符本身。 | 字符 | 说明 | | :--: | :-----: | | \d | 数字字符匹配。 | 等效于 [0-9]。 | 字符 | 说明 | | :--: | :------: | | \D | 非数字字符匹配。 | 等效于 \[^0-9]。 | 字符 | 说明 | | :--: | :----: | | \f | 换页符匹配。 | 等效于 \x0c 和 \cL。 | 字符 | 说明 | | :--: | :----: | | \n | 换行符匹配。 | 等效于 \x0a 和 \cJ。 | 字符 | 说明 | | :--: | :------: | | \r | 匹配一个回车符。 | 等效于 \x0d 和 \cM。 | 字符 | 说明 | | :--: | :---------------------: | | \s | 匹配任何空白字符,包括空格、制表符、换页符等。 | 与 [ \f\n\r\t\v] 等效。 | 字符 | 说明 | | :--: | :--------: | | \S | 匹配任何非空白字符。 | 与\[^ \f\n\r\t\v] 等效。 | 字符 | 说明 | | :--: | :----: | | \t | 制表符匹配。 | 与 \x09 和 \cI 等效。 | 字符 | 说明 | | :--: | :------: | | \v | 垂直制表符匹配。 | 与 \x0b 和 \cK 等效。 | 字符 | 说明 | | :--: | :-------------: | | \w | 匹配任何字类字符,包括下划线。 | 与"[A-Za-z0-9_]"等效。 | 字符 | 说明 | | :--: | :---------: | | \W | 与任何非单词字符匹配。 | 与\[^A-Za-z0-9_]"等效。 | 字符 | 说明 | | :---: | :------------------------: | | \x*n* | 匹配 *n*,此处的 *n* 是一个十六进制转义码。 | 十六进制转义码必须正好是两位数长。例如,"\x41"匹配"A"。"\x041"与"\x04"&"1"等效。允许在正则表达式中使用 ASCII 代码。 | 字符 | 说明 | | :--: | :------------------------: | | \num | 匹配 *num*,此处的 *num* 是一个正整数。 | 到捕获匹配的反向引用。例如,"(.)\1"匹配两个连续的相同字符。 | 字符 | 说明 | | :--: | :--------------: | | \n | 标识一个八进制转义码或反向引用。 | 如果 \n 前面至少有 *n* 个捕获子表达式,那么 *n* 是反向引用。否则,如果 *n* 是八进制数 (0-7),那么 *n* 是八进制转义码。 | 字符 | 说明 | | :--: | :--------------: | | \nm | 标识一个八进制转义码或反向引用。 | | 字符 | 说明 | | :--: | :------------------------------------: | | \un | 匹配 *n*,其中 *n* 是以四位十六进制数表示的 Unicode 字符。 | 例如,\u00A9 匹配版权符号 (©)。 ### Matcher类 ```java public class DoClient { public static void main(String[] args) { Pattern pattern = Pattern.compile("\\."); Matcher matcher = pattern.matcher("a.b.c"); } } ``` 查找方法`find()` > 尝试查找与该模式匹配的输入序列的下一个子序列。 ```java public class DoClient { public static void main(String[] args) { Pattern pattern = Pattern.compile("[a-z]"); Matcher matcher = pattern.matcher("****a.b.c****"); if (matcher.find()) { System.out.println(matcher.start()); } } } ``` 查找方法`find(int start)` > 重置此匹配器,然后尝试查找匹配该模式、从指定索引开始的输入序列的下一个子序列。 ```java public class DoClient { public static void main(String[] args) { Pattern pattern = Pattern.compile("[a-z]"); Matcher matcher = pattern.matcher("****a.b.c****"); if (matcher.find(7)) { System.out.println(matcher.start()); } } } ``` 查找方法`matches()` > 尝试将整个区域与模式匹配。 ```java public class DoClient { public static void main(String[] args) { Pattern pattern = Pattern.compile("[a-z]+"); Matcher matcher = pattern.matcher("abc"); if (matcher.matches()) { System.out.println(matcher.start()); } } } ``` 查找方法`lookingAt()` > 尝试将从区域开头开始的输入序列与该模式匹配。 ```java public class DoClient { public static void main(String[] args) { Pattern pattern = Pattern.compile("[a-z]+"); Matcher matcher = pattern.matcher("!abc"); if (matcher.lookingAt()) { System.out.println(matcher.start()); } } } ``` 索引方法`start()、end()` ```java System.out.println(matcher.start()); System.out.println(matcher.end()); ```