前言
同事把一个excel表给我,里面的数据大概有几千的样子吧。自己需要把里面的数据一个一个拿出来做一个http请求,对得到的结果进行过滤,然后再写到上面去。这是就涉及到用脚本来进行操作了,于是自己搞了一个Java的脚本出来,里面涉及到一些正则表达式,自己虽然说会,但是一直对 Matcher类中的group方法 不太了解。网上的博客也没有写的特别清楚,于是有了此文。
0|1Pattern 和 Matcher
在java.util.regex 包下
0|1正则表达式语法
在有的语言中,一个反斜杠 \ 就足以具有转义的作用,但是Java中需要两个 \\ 反斜杠。表示转义的作用。一些字符在正则表达式中的说明,意义。详情可查看runoob
0|1上代码
现在我的正则表达式为 (//d+)([a-z]+)(//d+)
public static void main( String args[] ){ // 按指定模式在字符串查找 String line = "123ra9040 123123aj234 adf12322ad 222jsk22"; String pattern = "(\\d+)([a-z]+)(\\d+)"; // String pattern1 = "([\\u4E00-\\u9FA5]+|\\w+)"; // 创建 Pattern 对象 Pattern r = Pattern.compile(pattern); // 现在创建 matcher 对象 Matcher m = r.matcher(line); int i = 0; // m.find 是否找到正则表达式中符合条件的字符串 while (m.find( )) { // 拿到上面匹配到的数据 System.out.println("----i="+i); System.out.println("Found value: " + m.group(0) ); System.out.println("Found value: " + m.group(1) ); System.out.println("Found value: " + m.group(2) ); System.out.println("Found value: " + m.group(3) ); i++; System.out.println("|||||||"); System.out.println(""); } }
输出:
----i=0
Found value: 123ra9040
Found value: 123
Found value: ra
Found value: 9040
|||||||
----i=1
Found value: 123123aj234
Found value: 123123
Found value: aj
Found value: 234
|||||||
----i=2
Found value: 222jsk22
Found value: 222
Found value: jsk
Found value: 22
|||||||
group(0) 对应着 ((//d+)([a-z]+)(//d+)) 123ra9040
group(2) 输出的数据 是 group(0)中所匹配的数据 也就是([a-z]+) 匹配到是数据 ra
group(3) 输出的数据 是 group(0)中所匹配的数据 也就是(//d+) 匹配到是数据 9040
0|1总结
Matcher 类中group(0) 表示正则表达式中符合条件的字符串。
Matcher 类中 group(1) 表示正则表达式中符合条件的字符串中的第一个() 中的字符串。
Matcher 类中 group(2) 表示正则表达式中符合条件的字符串中的第二个() 中的字符串。
Matcher 类中 group(3) 表示正则表达式中符合条件的字符串中的第三个() 中的字符串。
如果不明白,我相信看代码会很明白的。
总结
以上所述是小编给大家介绍的正则表达式Matcher类中group方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。