示例

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我的邮箱是:aaa@aaa.com");
        System.out.println(Arrays.toString(splitStrs));//[我的QQ是:, 我的电话是:, 我的邮箱是:aaa@aaa.com]

        //快速匹配字符串,该方法适合用于只匹配一次且匹配全部字符串
        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 我的邮箱是:aaa123@aaa.com");
        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()    返回此模式的字符串表示形式。

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

  1. java常用类与包装类--常用类正则表达式 String正则方法+Matcher+Pattern

    0.java中的正则 java 中的正则总共涉及三个类(或者说1个String类和一个regex包) java.lang.String java.util. Matcher java.util.Pat ...

  2. Regex分组与Pattern正则表达式对象

    1.正则规则:        1.String  regex  =  "[1-9]"          表示单个字符的取值范围是 1~9,注意是单个字符的取值范围        2 ...

  3. java.util.regex.Pattern正则表达式写验证器示例

    import java.util.regex.Pattern; /** * 校验器:利用正则表达式校验邮箱.手机号等 * */ public class Validator { /** * 正则表达式 ...

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

    在上一篇文章中,我们介绍了 Python 的捕获组和特殊匹配字符串,现在我们介绍 Python 的正则表达式使用示例.查看上一篇文章请点击:https://www.cnblogs.com/dustma ...

  5. Python,正则表达式 - (?:)示例

    例如正则表达式a(?:b),匹配后没有包含'b'的分组 >>> string 'ab ac' >>> import re >>> string = ...

  6. [Go] 正则表达式 示例

    package main import "bytes" import "fmt" import "regexp" func main() { ...

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

    java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表 ...

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

    java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表 ...

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

    java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和 Matcher Pattern 一个Pattern是一个正则表达式经编译后的 ...

随机推荐

  1. javascript禁止输入数字

    function onkeypressIsNumber(){ var mainForm = document.mainForm;//mainForm是form表单的ID for(var i=0; i& ...

  2. Bootstrap_排版_标题

    Bootstrap和普通的HTML页面一样,定义标题都是使用标签<h1>到<h6>,只不过Bootstrap覆盖了其默认的样式,使用其在所有浏览器下显示的效果一样,具体定义的规 ...

  3. ES5数组方法

    先标明参考出处: http://blog.csdn.net/codebistu/article/details/8049705 本来写过一篇有关数组新方法的(详见: [转]JavaScript函数和数 ...

  4. js中定义变量加var与不加var的区别?

    var 不一定是用来定义局部变量的 jscript的全局变量和局部变量的分界是这样的:                  过程体(包括方法function,对象Object o ={})外的所有变量不 ...

  5. git stash 保存修改现场

    用途:当你正在分支上做一个项目的时候,突然必须停下来去做别的事情,但因为没有此项目还没改好,所以不想commit 就可以保留现场,等忙完后再回复现场继续修改. bug处理保存开发现场$ git sta ...

  6. nginx+tomcat 配置虚拟目录。。

    之前nginx作为代理.之前的location写的太绝对了..之前把动态请求全部交给tomcat,然后需要配置虚拟路径的时候,去到tomcat就被404了.得高人指点之后,配置虚拟目录的时候需要重新写 ...

  7. H.264 Quantization

    H.264 Quantizer 一般的量化器,可用下面的公式来表示: $Z=\pm \left \lfloor\frac{ \left | W \right | }{\bigtriangleup }\ ...

  8. zoj 1010 Area【线段相交问题】

    链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1010 http://acm.hust.edu.cn/vjudge/ ...

  9. js类型判断及鸭式辨型

    目录 instanceof constructor 构造函数名字 鸭式辨型 三种检测对象的类方式: instanceof.constructor .构造函数名字 用法如下: 1)instanceof ...

  10. HDOJ(HDU) 1877 又一版 A+B(进制、、)

    Problem Description 输入两个不超过整型定义的非负10进制整数A和B(<=231-1),输出A+B的m (1 < m <10)进制数. Input 输入格式:测试输 ...