问题描述

需要使用正则表达式匹配到多个结果,并获取到多个结果:例如需要匹配如下中括号的(包括中括号)然后替换调中括号中的字(包括中括号),最后的结果是abcdefghk

abc[笑a哭][笑b哭][笑c哭]def[笑d哭][笑e哭][笑f哭]ghk

思路

1.需要用到正则表达式中非贪婪的匹配。也就是以字符 "["开始,字符“]”结束,而且是越短越好。也就是非贪婪的表达

字符 功能
* 匹配前一个字符出现0次或者无限次,即可有可无
+ 匹配前一个字符出现1次或者无限次,即至少有1次
? 匹配前一个字符出现1次或者0次,即要么有1次,要么没有

贪婪模式在整个表达式匹配成功的前提下,尽可能多的匹配,而非贪婪模式在整个表达式匹配成功的前提下,尽可能少的匹配

2.如果匹配到了多个,如何将所有匹配到的结果,打印,或是替换调。需要使用到while循环
3.提供一个在线的测试网址 http://tool.chinaz.com/regex/
在这里插入图片描述

其中匹配到的不同颜色,表示匹配到了多个,现在需要获取到匹配到的每一个 需要使用while

代码实现

	public static void main(String[] args) {
		String title = "abc[笑a哭][笑b哭][笑c哭]def[笑d哭][笑e哭][笑f哭]ghk";
//		String regex = "(\\[[\\u4e00-\\u9fa5].+?\\])"; //   \u4e00-\u9fa5,表示匹配到中文
		String regex = "(\\[[\\w\\W].+?\\])";
		Pattern p = Pattern.compile(regex);
		Matcher m = p.matcher(title);
		while(m.find()){
			String group = m.group();
			title = title.replace(group, "");
			System.out.println(title);
		}
	}

结果

abc[笑b哭][笑c哭]def[笑d哭][笑e哭][笑f哭]ghk
abc[笑c哭]def[笑d哭][笑e哭][笑f哭]ghk
abcdef[笑d哭][笑e哭][笑f哭]ghk
abcdef[笑e哭][笑f哭]ghk
abcdef[笑f哭]ghk
abcdefghk

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐