Java正则表达式的替换和分组功能
前言
这篇来学习正则表达式的替换和分组功能,替换很好理解,分组有点复杂,特别是如何写有效的分组的正则表达式。这篇通过几个练习,简单了解下替换和分组功能。
1.替换功能
在String类有一个替换功能的方法,结合正则表达式去实现替换,下面是replaceAll()方法的举例。
packageregex;
publicclassDemo1_Regex{
publicstaticvoidmain(String[]args){
Stringstr="wo1shi2zhong3guo4ren";
//需要替换得到woshizhongguoren
//写一个正则,用空字符替换原字符串的任意数字
Stringregex="\\d";//\d表示任意数字
Stringtarget=str.replaceAll(regex,"");
System.out.println(target);
}
}
2.分组功能
先来看看什么是分组,在API中Pattern这个类介绍是这样描述的:
捕获组可以通过从左到右计算其开括号来编号。例如,在表达式((A)(B(C)))中,存在四个这样的组:
|
1 |
((A)(B(C))) |
|
2 |
(A) |
|
3 |
(B(C)) |
|
4 |
(C) |
我们可以根据数多少个左括号来确定有多少个组。
下面来代码举例分组的正则表达式用法。
packageregex;
publicclassDemo1_Regex{
publicstaticvoidmain(String[]args){
//1叠词:快快乐乐,高高高兴兴
//判断字符串是否是上面的叠词规则
Stringregex="(.)\\1(.)\\2";//这个正则表达式表示快快乐乐这样的叠词
//上面(.)表示一个分组,里面.表示任意字符,\\1表示组1又出现了一次,\\2表示组2又出现了一次
System.out.println("快快乐乐".matches(regex));
System.out.println("快乐快乐".matches(regex));
System.out.println("高高兴兴".matches(regex));
System.out.println("快乐乐乐".matches(regex));
}
}
那么如何写“快乐快乐”这样叠词的正则表达式呢。这么去分析一下,字符串“快乐快乐”,可以认为“快乐”这个组又出现了一次,结合上面代码提到的知识,我们应该这样写。
packageregex;
publicclassDemo1_Regex{
publicstaticvoidmain(String[]args){
//1叠词:快乐快乐
Stringregex="(..)\\1";
System.out.println("快快乐乐".matches(regex));
System.out.println("快乐快乐".matches(regex));
}
}
练习1:按照叠词进行切割
请按照叠词进行切割“sdqqfgkkkhjppppdk”
packageregex;
publicclassDemo1_Split{
publicstaticvoidmain(String[]args){
Stringst="sdqqfgkkkhjppppkl";
String[]arr=st.split("(.)\\1+");
for(inti=0;i
输出
sd
fg
hj
kl
总结
到此这篇关于Java正则表达式的替换和分组功能的文章就介绍到这了,更多相关Java正则的替换和分组内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。