Matcher Pattern 正则表达式 示例

示例


public class Test {

    public static void main(String[] args) throws IOException {

        Pattern p = Pattern.compile("\\d+");//Pattern类用于创建一个正则表达式(匹配模式)。匹配一个或多个数字字符。等价于 [0-9]+

        Matcher m = p.matcher("22bb23");//返回正则表达式的字符串形式(将给定的正则表达式编译到模式中)

        //分隔字符串,并返回一个String[]         String[] splitStrs = p.split("我的QQ是:456456我的电话是:0532214我的邮箱是:[email protected]");         System.out.println(Arrays.toString(splitStrs));//[我的QQ是:, 我的电话是:, 我的邮箱是:[email protected]]
        //快速匹配字符串,该方法适合用于只匹配一次且匹配全部字符串         System.out.println(Pattern.matches("\\d+", "1243"));//true          System.out.println(Pattern.compile("\\d+").matcher("1243").matches());//true         System.out.println(Pattern.matches("\\d+", "1243aa"));//false。需要匹配到所有字符串才能返回true,这里aa不能匹配到          System.out.println(Pattern.matches("\\d+", "12bb43") + "\n");//false
        //Pattern类只能做一些简单的匹配操作,Matcher类提供了对正则表达式的分组支持,以及对正则表达式的多次匹配支持         System.out.println(p == m.pattern());//true,返回创建该Matcher对象的哪个Pattern对象         //matches():对整个字符串进行匹配,只有整个字符串都匹配了才返回true         System.out.println("是否匹配:" + p.matcher("22bb23").matches());//false。因为bb不能被\d+匹配,导致整个字符串匹配未成功.         System.out.println("是否匹配:" + p.matcher("2223").matches());//true         //lookingAt():对前面的字符串进行匹配,只要最前面的字符串能匹配到就返回true         System.out.println(p.matcher("2bbb23").lookingAt());//true,因为\d+匹配到了最前面的2         System.out.println(p.matcher("a12223").lookingAt() + "\n");//false,因为\d+不能匹配最前面的a         //find():对字符串进行匹配,匹配到的字符串可以在任何位置         System.out.println("是否找到:" + p.matcher("aa2").find());//true         System.out.println("是否找到:" + p.matcher("aa2223bb").find());//true         System.out.println("是否找到:" + p.matcher("aabb").find() + "\n");//false
        //当使用matches()、lookingAt()、find()执行匹配操作后,就可以利用以下三个方法得到更详细的信息         m = p.matcher("我的QQ是:456456 我的电话是:0532214 我的邮箱是:[email protected]");         while (m.find()) {//注意:matcher只有在执行这几个方法后且返回true时才能执行以下方法,否则报 IllegalStateException: No match available             //返回匹配到的子字符串,及其第一个/最后一个字符,在字符串中的索引位置,范围仍然为【[ , )】             System.out.println("查找  " + m.group() + ": " + m.start() + "-" + m.end());////【456456: 6-12】【0532214: 19-26】【123: 36-39】         }         m = p.matcher("21bb");         if (m.lookingAt()) {//这里若用用while会导致死循环             System.out.println("lookingAt  " + m.group() + ": " + m.start() + "-" + m.end() + "\n");//lookingAt  21: 0-2         }
        //【这里不是很明白】start()、end()、group()均有一个带int参数的重载方法,专用于分组操作;groupCount()用于返回有多少组         //捕获组可以通过从左到右计算其开括号来编号,编号是从1 开始的。例如,在 ((A)(B(C)))中,存在四个这样的组【1 ((A)(B(C)));2 (A);3 (B(C));4 (C)】         //组零始终代表整个表达式。 以 (?) 开头的组是纯的非捕获组,它不捕获文本,也不针对组合计进行计数。         p = Pattern.compile("([a-z]+)(\\d+)");         m = p.matcher("aa22bb33cc44");         if (m.find()) {             int count = m.groupCount();             for (int i = 1; i <= count; i++) {//注意是从1开始的                 System.out.println("分组" + i + "  " + m.group(i) + ":" + m.start(i) + "-" + m.end(i));//【分组1  aa:0-2】【分组2  22:2-4】             }         }
        //可以先后使用 appendReplacement 和 appendTail 方法将结果收集到现有的字符串缓冲区         p = Pattern.compile("cat");         m = p.matcher("one cat two cats in the yard");         StringBuffer buffer = new StringBuffer();         while (m.find()) {             m.appendReplacement(buffer, "dog");//实现非终端添加和替换步骤,返回匹配器         }         m.appendTail(buffer);//实现终端添加和替换步骤,返回目标字符串缓冲区(即参数本身)         System.out.println("appendTail:  " + buffer.toString());//one dog two dogs in the yard
        //replaceFirst :替换模式与给定替换字符串匹配的输入序列的第一个子序列         String result = "";         m = p.matcher("one cat two cats in the yard");         if (m.find()) {//只能使用if             result = m.replaceFirst("包青天");//调用此方法将更改此匹配器的状态。如果在将来的匹配操作中使用该匹配器,则应该首先重置它         }         System.out.println("replaceFirst:  " + result);//one 包青天 two cats in the yard
        m = p.matcher("one cat two cats in the yard");         while (m.find()) {             result = m.replaceFirst("包青天");//调用此方法将更改此匹配器的状态。如果在将来的匹配操作中使用该匹配器,则应该首先重置它             m = p.matcher(result);         }         System.out.println("replaceFirst+while:  " + result);//one 包青天 two 包青天s in the yard
        m = p.matcher("one cat two cats in the yard");         while (m.find()) {             result = m.replaceAll("白乾涛");//调用此方法将更改此匹配器的状态。如果在将来的匹配操作中使用该匹配器,则应该首先重置它         }         System.out.println("replaceAll:  " + result);//one 白乾涛 two 白乾涛s in the yard     } }

Matcher API


appendReplacement(StringBuffer sb, String replacement)    实现非终端添加和替换步骤。

appendTail(StringBuffer sb)    实现终端添加和替换步骤。

end()    返回最后匹配字符之后的偏移量。

end(int group)    返回在以前的匹配操作期间,由给定组所捕获子序列的最后字符之后的偏移量。

find()    尝试查找与该模式匹配的输入序列的下一个子序列。

find(int start)    重置此匹配器,然后尝试查找匹配该模式、从指定索引开始的输入序列的下一个子序列。

group()    返回由以前匹配操作所匹配的输入子序列。

group(int group)    返回在以前匹配操作期间由给定组捕获的输入子序列。

groupCount()    返回此匹配器模式中的捕获组数。

hasAnchoringBounds()    查询此匹配器区域界限的定位。

hasTransparentBounds()    查询此匹配器区域边界的透明度。

hitEnd()    如果匹配器执行的最后匹配操作中搜索引擎遇到输入结尾,则返回 true。

lookingAt()    尝试将从区域开头开始的输入序列与该模式匹配。

matches()    尝试将整个区域与模式匹配。

pattern()    返回由此匹配器解释的模式。

quoteReplacement(String s)    返回指定 String 的字面值替换 String。

region(int start, int end)    设置此匹配器的区域限制。

regionEnd()    报告此匹配器区域的结束索引(不包括)。

regionStart()    报告此匹配器区域的开始索引。

replaceAll(String replacement)    替换模式与给定替换字符串相匹配的输入序列的每个子序列。

replaceFirst(String replacement)    替换模式与给定替换字符串匹配的输入序列的第一个子序列。

requireEnd()    如果很多输入都可以将正匹配更改为负匹配,则返回 true。

reset()    重置匹配器。

reset(CharSequence input)    重置此具有新输入序列的匹配器。

start()    返回以前匹配的初始索引。

start(int group)    返回在以前的匹配操作期间,由给定组所捕获的子序列的初始索引。

toMatchResult()    作为 MatchResult 返回此匹配器的匹配状态。

toString()    返回匹配器的字符串表示形式。

useAnchoringBounds(boolean b)    设置匹配器区域界限的定位。

usePattern(Pattern newPattern)    更改此 Matcher 用于查找匹配项的 Pattern。

useTransparentBounds(boolean b)    设置此匹配器区域边界的透明度。

Pattern API


compile(String regex)    将给定的正则表达式编译到模式中。

compile(String regex, int flags)    将给定的正则表达式编译到具有给定标志的模式中。

flags()    返回此模式的匹配标志。

matcher(CharSequence input)    创建匹配给定输入与此模式的匹配器。

matches(String regex, CharSequence input)    编译给定正则表达式并尝试将给定输入与其匹配。

pattern()    返回在其中编译过此模式的正则表达式。

quote(String s)    返回指定 String 的字面值模式 String。

split(CharSequence input)    围绕此模式的匹配拆分给定输入序列。

split(CharSequence input, int limit)    围绕此模式的匹配拆分给定输入序列。

toString()    返回此模式的字符串表示形式。

来自为知笔记(Wiz)

时间: 2024-08-07 16:45:44

Matcher Pattern 正则表达式 示例的相关文章

Visual Studio .Net使用正则表达式示例

有一段Java代码 public final String ACode="a"; public final String BCode="b"; public final String CCode="c"; public final String DCode="d"; public final String ECode="e"; public final String FCode="f";

正则表达式 - 示例

正则表达式 - 示例 简单表达式 正则表达式的最简单形式是在搜索字符串中匹配其本身的单个普通字符.例如,单字符模式,如 A,不论出现在搜索字符串中的何处,它总是匹配字母 A.下面是一些单字符正则表达式模式的示例: /a/ /7/ /M/ 可以将许多单字符组合起来以形成大的表达式.例如,以下正则表达式组合了单字符表达式:a.7 和 M. /a7M/ 请注意,没有串联运算符.只须在一个字符后面键入另一个字符. 字符匹配 句点 (.) 匹配字符串中的各种打印或非打印字符,只有一个字符例外.这个例外就是

Java正则表达式示例

import java.util.regex.Matcher; import java.util.regex.Pattern; public class RegexMatches { public static void main( String args[] ){ // 按指定模式在字符串查找 String line = "This order was placed for QT3000! OK?"; String pattern = "(.*)(\\d+)(.*)&quo

Python学习手册之正则表达式示例--邮箱地址提取

在上一篇文章中,我们介绍了 Python 的捕获组和特殊匹配字符串,现在我们介绍 Python 的正则表达式使用示例.查看上一篇文章请点击:https://www.cnblogs.com/dustman/p/10040430.html 邮箱地址提取为了演示正则表达式的示例用法,我们创建一个从字符串中提取电子邮箱地址的程序.假设我们有一个包含电子邮箱地址的字符串. string = "Please contact [email protected] for assistance" 我们希

linux学习-grep使用正则表达式示例

在linux上使用grep配合正则表达式可以产生强大的搜索的效果,由于正则表达式中含有较多的特殊字符,所以结合grep时,最好使用单引号将表达式括起来,以免造成错误.首先创建一个文件RegExp.txt,文本内容如下所示: --------TEXT BEGIN------------- good morining teacher hellp world is as script gold sunshine looks beautiful golden time files god belss m

JAVA正则表达式:Pattern类与Matcher类详解(转)

java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表现模式. Matcher 一个Matcher对象是一个状态机器,它依据Pattern对象做为匹配模式对字符串展开匹配检查. 首先一个Pattern实例订制了一个所用语法与PERL的类似的正则表达式经编译后的模式,然后一个Matcher实例在这个给定的Pattern实例的模式控制下进行字符串的匹配工作

JAVA正则表达式:Pattern类与Matcher类详解

java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表现模式. Matcher 一个Matcher对象是一个状态机器,它依据Pattern对象做为匹配模式对字符串展开匹配检查. 首先一个Pattern实例订制了一个所用语法与PERL的类似的正则表达式经编译后的模式,然后一个Matcher实例在这个给定的Pattern实例的模式控制下进行字符串的匹配工作

Java正则表达式Pattern和Matcher类

转载自--小鱼儿是坏蛋(原文链接) 概述 Pattern类的作用在于编译正则表达式后创建一个匹配模式.    Matcher类使用Pattern实例提供的模式信息对正则表达式进行匹配 Pattern类常用方法及介绍 1.  Pattern complie(String regex)    由于Pattern的构造函数是私有的,不可以直接创建,所以通过静态方法compile(String regex)方法来创建,将给定的正则表 达式编译并赋予给Pattern类 2.  String pattern

从头认识java-11.4 正则表达式(3)-Pattern和Matcher

这一章节我们来讨论一下Pattern和Matcher. 之前我们都是简单的使用正则表达式来匹配字符串,其实java里面提供了强大的正则匹配类,我们下面将以几个例子来说明. package com.ray.ch11; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Test { public static void main(String[] args) { String testStr =