本文目录一览:
- 1、JAVA正则表达式,matcher.find和 matcher.matches的区别
- 2、java matcher方法
- 3、java 正则表达式中matcher类起什么作用
- 4、Java中正则Matcher类的matches,lookAt和find的区别
- 5、Java中Matcher在while loop中的异常行为
- 6、JavaSE基础中正则表达式Matcher类的获取功能--group(),解惑必采纳,谢谢
JAVA正则表达式,matcher.find和 matcher.matches的区别
1.find()方法是部分匹配,是查找输入串中与模式匹配的子串,如果该匹配的串有组还可以使用group()函数。
matches()是全部匹配,是将整个输入串与模式匹配,如果要验证一个输入的数据是否为数字类型或其他类型,一般要用matches()。
2.Pattern pattern= Pattern.compile(".*?,(.*)");
Matcher matcher = pattern.matcher(result);
if (matcher.find()) {
return matcher.group(1);
}
3.详解:
matches
public static boolean matches(String regex, CharSequence input)
编译给定正则表达式并尝试将给定输入与其匹配。
调用此便捷方法的形式
Pattern.matches(regex, input);
Pattern.compile(regex).matcher(input).matches() ;
如果要多次使用一种模式,编译一次后重用此模式比每次都调用此方法效率更高。
参数:
regex - 要编译的表达式
input - 要匹配的字符序列
抛出:
PatternSyntaxException - 如果表达式的语法无效
find
public boolean find()尝试查找与该模式匹配的输入序列的下一个子序列。
此方法从匹配器区域的开头开始,如果该方法的前一次调用成功了并且从那时开始匹配器没有被重置,则从以前匹配操作没有匹配的第一个字符开始。
如果匹配成功,则可以通过 start、end 和 group 方法获取更多信息。
matcher.start() 返回匹配到的子字符串在字符串中的索引位置.
matcher.end()返回匹配到的子字符串的最后一个字符在字符串中的索引位置.
matcher.group()返回匹配到的子字符串
返回:
当且仅当输入序列的子序列匹配此匹配器的模式时才返回 true。
java matcher方法
看一下Pattern的matcher方法就知道了
/**
* Creates a matcher that will match the given input against this pattern.
* /p
*
* @param input
* The character sequence to be matched
*
* @return A new matcher for this pattern
*/
public Matcher matcher(CharSequence input) {
if (!compiled) {
synchronized(this) {
if (!compiled)
compile();
}
}
Matcher m = new Matcher(this, input);
return m;
}
它返回的是一个新的Matcher对象, 再执行它的matches()方法.
遇到不懂的时候看看源代码就一目了然啦
java 正则表达式中matcher类起什么作用
指定为字符串的Java正则表达式必须首先被编译为pattern类的实例。然后,可将得到的模式用于创建 Matcher 对象,依照Java正则表达式,该对象可以与任意字符序列匹配。执行匹配所涉及的所有状态都驻留在匹配器中,所以多个匹配器可以共享同一模式。
因此,典型的调用顺序是
Pattern p = Pattern.compile("a*b");
Matcher m = p.matcher("aaaaab");
boolean b = m.matches();
Java中正则Matcher类的matches,lookAt和find的区别
matches匹配的是整个输入序列,如果你了解整个输入序列的结构,想从中查找各个部分或者校验序列的合法性,则使用matches。
lookAt匹配的是输入序列的开始,如果你只对输入序列的开始部分感兴趣,则使用lookAt。与matches的区别就是只要匹配到就结束,而不会匹配整个序列。
find是从输入序列中查询匹配到的串,如果你希望在输入序列中寻找匹配的串,则使用find。
有一点要说明的是如果希望对不限定次数重复出现的串单独进行处理,则必须使用find,matches和lookAt使用捕获组也只能把这些串合并起来处理。
Java中Matcher在while loop中的异常行为
String loop = "a b c d e f g h i j k l";
Matcher loopMatcher = Pattern.compile("\\S+").matcher(loop);
boolean loopEnded = false;
while (!loopEnded) {
use(matcher);
if (matcher.hitEnd()) {
loopEnded = true;
}
}
public static void use(Matcher matcher) {
if (!matcher.find()) {
System.out.println("loop not ended but matcher hit end");
}
}
运行后发现会输出错误信息,循环到最后判断一下就好了。
JavaSE基础中正则表达式Matcher类的获取功能--group(),解惑必采纳,谢谢
在Java中,正则表达式是按照从左至右的顺序对字符串进行扫描匹配的,首先,find()和group()都是Matcher类的函数,而不是String类的函数,所以find()和group()是对字符串从左至右扫描的函数,而不是对同一字符串反复扫描的函数.
比如m.find()函数,如果找到匹配的子字符串,它返回true,没有找到匹配的子字符串,它返回false.当写到while条件中时,它表示持续在原字符串中从左至右扫描,当发现有匹配的子字符串时,由m.group()捕获并输出,如果扫描到原字符串尾也没有发现匹配的子字符串,则返回false,跳出循环.
以你的程序为例,m.find()函数会在原字符串中持续从左至右扫描三个字符的以空格为边界的单词,直到字符串尾,而不会反复从头开始扫描原字符串,除非你在while循环中使用while(m.find(0)),m.find(0)表示从原字符串的第一个字符开始扫描匹配的子字符串,这样程序会反复从原字符串的第一个字符开始扫描匹配的子字符串,会陷入无限循环.
也就是说,find()和group()函数,只会对原字符串从左至右扫描一遍,这样当第二次while循环时,不会是从原字符串头重新开始,而是从上一次匹配的位置后面开始第二次搜寻.