示例

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. Linux硬盘命名和安装分区

    硬盘命名: 硬盘命名基于文件,一般有如下文件方式: /dev/hda1 /dev/sdb3 具体含义如下: /dev:是所有设备文件存放的目录. hd和sd:他们是区别的前两个字母,代表该分区所在的设 ...

  2. sae crop 文档

    原文是google缓存:http://webcache.googleusercontent.com/search?q=cache:MD_FP-G6RI8J:sae.sina.com.cn/%3Fm%3 ...

  3. c#中使用easyUI的DataGrid组件

    前台页面 html <table id="dg"> </table> JavaScript $("#dg").datagrid({ wi ...

  4. 手写 title 提示

    jquery实现 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  5. Python第三方库(模块)"scikit learn"以及其他库的安装

    scikit-learn是一个用于机器学习的 Python 模块. 其主页:http://scikit-learn.org/stable/. GitHub地址: https://github.com/ ...

  6. 在同个工程中使用 Swift 和 Objective-C(Swift 2.0更新)-b

    本节包含内容: Mix and Match 概述(Mix and Match Overview) 在同个应用的 target 中导入(Importing Code from Within the Sa ...

  7. html5 中常用的标签和属性

    标签: <blockquote> 标签定义摘自另一个源的块引用. <blockquote> 与 </blockquote> 之间的所有文本都会从常规文本中分离出来, ...

  8. 转:快乐Node码农的十个习惯

    文章来源于:http://www.infoq.com/cn/articles/node.js-habits 从问世到现在将近20年,JavaScript一直缺乏其它有吸引力的编程语言,比如Python ...

  9. centos7 jsoup java.net.UnknownHostException

    [root@localhost ~]# vi /etc/hosts127.0.0.1 localhost localhost.localdomain localhost4 localhost4.loc ...

  10. 阿里云服务器重启后mysql不能启动的问题

    环境:阿里云ECS服务器上,Ubuntu linux 12.04,64位版.MySQL 5.1. 首先查看/etc/rc.local,可以看到Ubuntu通过/etc/init.d/mysqld脚本启 ...