/*
* 正则表达式对字符串的常见操作:
* 3.替换
* 其实使用的就是String类中的replaceAll()方法。
*/
package demo;
public class Demo {
public static void main(String[] args) {
FunctionDemo_3();
}
public static void FunctionDemo() {
String str = "zhangsantttxiaoqiangmmmzhaoliu";
String regex = "(.)\\1+";
/*
* 这里.表示任意字符,(.)表示一个捕获组,其内是重叠字母,\\表示\,\\1表示\1,即一个捕获组,1+表示一个或多个捕获组,
* 即regex表示所有重复字母。详见API正则表达式。
* (过程:z是任意字符?是,h与z匹配?不……直到第二个t与第一个t匹配,满足regex)
*/
str = str.replaceAll(regex, "#");//将所有满足regex的子串修改为#
System.out.println(str);//zhangsan#xiaoqiang#zhaoliu
}
public static void FunctionDemo_2() {
/*
* 【需求】将多个t变成一个t,多个m变成一个m
*/
String str = "zhangsantttxiaoqiangmmmzhaoliu";
String regex = "(.)\\1+";
str = str.replaceAll(regex, "$1");//美元符号用于获取regex的第一个字符
System.out.println(str);//zhangsantxiaoqiangmzhaoliu
}
public static void FunctionDemo_3() {
/*
* 【需求】模拟网上一个功能,用户输入电话号码15811112222后,在网站显示158****2222
*/
String tel = "15811112222";
String regex = "(\\d{3})\\d{4}(\\d{4})";
/*
* 解释:\\表示\,\\d表示\d,即纯0-9数字组合,{3}是取3位,所以第一组(\\d{3})表示取前3个0-9纯数字作为第一组,\\d{4}
* 同理,最后一组(\\d{4})同理。
*/
tel = tel.replaceAll(regex, "$1****$2");//取regex的第一组和第二组,中间用四个星号代替,实现需求
//【注意】这里没有第三组,就两组
System.out.println(tel);
}
}
28-正则表达式-05-正则表达式(常见的功能-替换)
最新推荐文章于 2024-01-10 07:15:00 发布