JAVA中使用正则表达式的若干方法,找到匹配的文本

Java经典实例:找到匹配的文本,java经典实例

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * Created by Frank
 */
public class REMatch {
    public static void main(String[] args) {
        String patt = "Q[^u]\d+\.";
        Pattern r = Pattern.compile(patt);
        String line = "Order QT300. Now! QT400.";
        Matcher m = r.matcher(line);
        int i = 0;
        while (m.find()) {
            // group(0)或group()将会返回整个匹配的字符串(完全匹配);group(i)则会返回与分组i匹配的字符
            // 这个例子只有一个分组
            System.out.println(patt + " matches "" + m.group(0) + "" in "" + line + """);
            System.out.println("start:" + m.start() + " end:" + m.end());
        }
    }
}

输出:

Q[^u]d+. matches "QT300." in "Order QT300. Now! QT400."
start:6 end:12
Q[^u]d+. matches "QT400." in "Order QT300. Now! QT400."
start:18 end:24

 

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * Created by Frank
 */
public class REMatchTwoFields {
    public static void main(String[] args) {
        String inputLine = "Adams,John Quincy";
        Pattern r = Pattern.compile("(.*),(.*)");
        Matcher m = r.matcher(inputLine);
        if (!m.matches()) {
            throw new IllegalArgumentException("Bad Input");
        }
        // 分组0得到的是整个原字符串
        for (int i = 0; i < m.groupCount() + 1; i++) {
            System.out.println("分组" + i + ":" + m.group(i));
        }
    }
}

输出:

分组0:Adams,John Quincy
分组1:Adams
分组2:John Quincy

 

import
java.util.regex.Matcher; import java.util.regex.Pattern; /** *
Created by Frank */ public class REMatch { public…

正则的具体写法不是重点,一般常用的还是比较简单的

主要想说的是在JAVA里使用正则的几种情况

先来定义两个变量:

 

1、被查找的字符串:str

2、要查找的关键字(或正则表达式):keywordPattern

 

情况一:判断str里是否含有keywordPattern

 

 1 import java.util.regex.Matcher;
 2  import java.util.regex.Pattern;
 3 
 4  public class RegTest {
 5     public static void main(String[] args) {
 6         String str = “我是人。。我是好人。。我是好男人。。- – !!”;
 7         Pattern keywordPattern = Pattern.compile(“好男人”);
 8         Matcher matcher = keywordPattern.matcher(str);
 9         System.out.println(str.find());
10     }
11 }

输出:true

 

情况二:判断str是否完全符合keywordPattern,可用于邮箱验证等情况

 

 1 public class RegTest {
 2     public static void main(String[] args) {
 3         String str = “abcd1234ABCD”;
 4         Pattern keywordPattern = Pattern.compile(“^[a-zA-Z0-9]+$”);
 5         Matcher matcher = keywordPattern.matcher(str);
 6 
 7         System.out.println(matcher.matches());
 8         //System.out.println(matcher.find()); 也可以实现同样的效果
 9      }
10 }

输出:true

 

情况三:将str中符合keywordPattern的字符都替换掉

发表评论

电子邮件地址不会被公开。 必填项已用*标注