import com.sun.org.apache.regexp.internal.RE;
public class regex {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String pattern="^Q[^u]\\d+\\.";
String input="QA777. is the next flight,It is on time.";
RE r=new RE(pattern);
boolean found=r.match(input);
System.out.println(pattern+(found ? "匹配" :"不匹配")+input);
//以Q开头并以.结尾,中间有多个字符
}
public class regex {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String pattern="^Q[^u]\\d+\\.";
String input="QA777. is the next flight,It is on time.";
RE r=new RE(pattern);
boolean found=r.match(input);
System.out.println(pattern+(found ? "匹配" :"不匹配")+input);
//以Q开头并以.结尾,中间有多个字符
}
}
输出结果:
^Q[^u]\d+\.匹配QA777. is the next flight,It is on time.
正则表达式公共API很大,它在程序中匹配的一般步骤是:
1.通过调用静态方法Pattern.compile()创建一个模式;
2.为每一个String调用pattern.matcher(CharSequence)以从模式中请求一个matcher;
3在结果中调用一次或多次finder方法;
例如:
Matcher m= Pattern.compile(patt).matcher(line);
if(m.find())
System.out.println(line+"matches"+patt);