•这里重点介绍最不好理解的\. 在Java中的字符串中, 如果要用到特殊字符, 必须通过在前面加\进行转义.
•举个例子, 考虑这个字符串"老师大声说:"同学们,快交作业!"". 如果我们没有转义字符, 那么开头的双引号的结束应该在说:"这里, 但是我们的字符串中需要用到双引号, 所以需要用转义字符
•使用转义字符后的字符串为"老师大声说:\"同学们,快交作业!\"", 这样我们的原意才能被正确识别.
•同理如果我们要在字符串中使用\, 也应该在前面加一个\, 所以在字符串中表示为"\\"
•那么如何在正则表达式中表示要匹配\呢, 答案为"\\\\".
•我们分开考虑: 由于正则式中表示\同样需要转义, 所以前面的\\表示正则表达式中的转义字符\, 后面的\\表示正则表达式中\本身, 合起来在正则表达式中表示\.
•如果感觉有点绕的话请看下面代码
public class Demo5 { private static void p(Object o){ System.out.println(o); } public static void main(String[] args) { /** * \d A digit: [0-9] 数字 * \D A non-digit: [^0-9] 非数字 * \s A whitespace character: [ \t\n\x0B\f\r] 空格 * \S A non-whitespace character: [^\s] 非空格 * \w A word character: [a-zA-Z_0-9] 数字字母和下划线 * \W A non-word character: [^\w] 非数字字母和下划线 */ // \\s{4}表示4个空白符 p(" \n\r\t".matches("\\s{4}")); // \\S表示非空白符 p("a".matches("\\S")); // \\w{3}表示数字字母和下划线 p("a_8".matches("\\w{3}")); p("abc888&^%".matches("[a-z]{1,3}\\d+[%^&*]+")); // 匹配 \ p("\\".matches("\\\\")); } } //输出结果
全部为true边界处理
•^在中括号内表示取反的意思[^], 如果不在中括号里则表示字符串的开头.
public class Demo6 { private static void p(Object o){ System.out.println(o); } public static void main(String[] args) { /** * ^ The beginning of a line 一个字符串的开始 * $ The end of a line 字符串的结束 * \b A word boundary 一个单词的边界, 可以是空格, 换行符等 */ p("hello sir".matches("^h.*")); p("hello sir".matches(".*r$")); p("hello sir".matches("^h[a-z]{1,3}o\\b.*")); p("hellosir".matches("^h[a-z]{1,3}o\\b.*")); } }
练习:匹配空白行合email地址•拿到一篇文章, 如何判断里面有多少个空白行? 用正则表达式能方便地进行匹配, 注意空白行中可能包括空格, 制表符等.
p(" \n".matches("^[\\s&&[^\n]]*\\n$"));
•解释: ^[\\s&&[^\n]]*是空格符号但不是换行符, \\n$最后以换行符结束
•下面是匹配邮箱
p("liuyj24@126.com".matches("[\\w[.-]]+@[\\w[.-]]+\\.[\\w]+"));
•解释: [\\w[.-]]+以一个或多个数字字母下划线.或-组成, @接着是个@符号, 然后同样是[\\w[.-]]+, 接着\\.匹配., 最后同样是[\\w]+
Matcher类的matches(),find()和lookingAt()
•matches()方法会将整个字符串与模板进行匹配.
•find()则是从当前位置开始进行匹配, 如果传入字符串后首先进行find(), 那么当前位置就是字符串的开头, 对当前位置的具体分析可以看下面的代码示例
•lookingAt()方法会从字符串的开头进行匹配.
public class Demo8 { private static void p(Object o){ System.out.println(o); } public static void main(String[] args) { Pattern pattern = Pattern.compile("\\d{3,5}"); String s = "123-34345-234-00"; Matcher m = pattern.matcher(s); //先演示matches(), 与整个字符串匹配. p(m.matches()); //结果为false, 显然要匹配3~5个数字会在-处匹配失败 //然后演示find(), 先使用reset()方法把当前位置设置为字符串的开头 m.reset(); p(m.find());//true 匹配123成功 p(m.find());//true 匹配34345成功 p(m.find());//true 匹配234成功 p(m.find());//false 匹配00失败 //下面我们演示不在matches()使用reset(), 看看当前位置的变化 m.reset();//先重置 p(m.matches());//false 匹配整个字符串失败, 当前位置来到- p(m.find());// true 匹配34345成功 p(m.find());// true 匹配234成功 p(m.find());// false 匹配00始边 p(m.find());// false 没有东西匹配, 失败 //演示lookingAt(), 从头开始找 p(m.lookingAt());//true 找到123, 成功 } }
Matcher类中的start()和end()•如果一次匹配成功的话start()用于返回匹配开始的位置, end()用于返回匹配结束字符的后面一个位置