java.util.regex
类 Pattern
java.lang.Object java.util.regex.Pattern
-
所有已实现的接口:
- Serializable
public final class Pattern extends Object implements Serializable
正则表达式的编译表示形式。
指定为字符串的正则表达式必须首先被编译为此类的实例。然后,可将得到的模式用于创建 Matcher
对象,依照正则表达式,该对象可以与任意字符序列
匹配。执行匹配所涉及的所有状态都驻留在匹配器中,所以多个匹配器可以共享同一模式。
因此,典型的调用顺序是
Pattern p = Pattern.compile
("a*b"); Matcher m = p.matcher
("aaaaab"); boolean b = m.matches
();
在仅使用一次正则表达式时,可以方便地通过此类定义 matches
方法。此方法编译表达式并在单个调用中将输入序列与其匹配。语句
等效于上面的三个语句,尽管对于重复的匹配而言它效率不高,因为它不允许重用已编译的模式。boolean b = Pattern.matches("a*b", "aaaaab");
此类的实例是不可变的,可供多个并发线程安全使用。Matcher
类的实例用于此目的则不安全。
具体使用方法可以参考API 1.4以上的版本 http://docs.oracle.com/javase/6/docs/api/
举一个很简单例子供自己参考。
需要从字符串中截取倒数第二个小数点 后面的字符串。
例如:String domain="http://www.baidu.com"。我需要截取baidu.com.
代码如下:
String domain = "aaab.ca.wapun.cn";
String regex = "[\\w]+\\.[\\w]+";
Matcher m = Pattern.compile(regex).matcher(domain);
String dst = null;
while (m.find()) {
dst = m.group();
}
System.out.println(dst);
提供网上比较好文章:http://blog.csdn.net/fpf_721521/article/details/4376448