正则表达式是一种强大而灵活的文本处理工具。使用它我们能以编程的方式,构造复杂的文本模式,并对输入的字符串进行搜索。一旦找到了匹配这些模式的部分,你就能够随心所欲地对它们进行处理。
关于正则表达式的语法,网上对此有介绍的文章实在是多不胜数,实在找不到,还可以查看Java的API文档,就不多介绍了。这里主要介绍一个可以测试正则表达式的小工具。直接上代码:
1 package com.test.stringregex; 2 //{Args: abcabcabcdefabc "abc+" "(abc)+" "(abc){2,}"} 3 import java.util.regex.Matcher; 4 import java.util.regex.Pattern; 5 6 public class TestRegularExpression { 7 public static void main(String[] args) { 8 if(args.length < 2) { 9 System.out.println("Usage:\njava TestRegularExpression " + 10 "characterSequence regularExpression+"); 11 System.exit(0); 12 } 13 System.out.println("Input: \"" + args[0] + "\""); 14 for(String arg : args) { 15 System.out.println("Regular expression: \"" + arg + "\""); 16 Pattern p = Pattern.compile(arg); 17 Matcher m = p.matcher(args[0]); 18 while(m.find()) { 19 System.out.println("Match \"" + m.group() + "\" at positions " + 20 m.start() + "-" + (m.end() - 1)); 21 } 22 } 23 } 24 }
输入测试的参数为注释中的{Args: abcabcabcdefabc "abc+" "(abc)+" "(abc){2,}"},结果如下
第一个控制台参数是将要用来搜索匹配的输入字符串,后面的一个或多个参数都是正则表达式,用""括起来,这里我分别测试了3个正则表达式"abc+" "(abc)+" "(abc){2,}",在实际使用的过程中可以替换成你想要测试的表达式,以验证它们是不是具备你所需要的匹配功能。
Pattern对象表示编译后的正则表达式,已编译的Pattern对象上的matcher()方法,加上一个输入字符串,共同构造了一个Matcher()对象。通过调用Matcher()对象的find(),group(),start(),end()方法构成了这个工具类直观的输出,正则表达式是否匹配,如何匹配目标字符串(即参数args(0))一目了然。
原文:http://www.cnblogs.com/junqiao/p/6637410.html