当前位置: 首页 > 编程笔记 >

Java正则表达式的替换和分组功能

公孙和怡
2023-03-14
本文向大家介绍Java正则表达式的替换和分组功能,包括了Java正则表达式的替换和分组功能的使用技巧和注意事项,需要的朋友参考一下

前言

这篇来学习正则表达式的替换和分组功能,替换很好理解,分组有点复杂,特别是如何写有效的分组的正则表达式。这篇通过几个练习,简单了解下替换和分组功能。

1.替换功能

在String类有一个替换功能的方法,结合正则表达式去实现替换,下面是replaceAll()方法的举例

package regex;
 
public class Demo1_Regex {
	
	public static void main(String[] args) {
		String str = "wo1shi2zhong3guo4ren";
		//需要替换得到 wo shi zhong guo ren
		//写一个正则,用空字符替换原字符串的任意数字
		String regex = "\\d"; // \d表示任意数字
		
		String target = str.replaceAll(regex, " ");
		System.out.println(target);
	}
 
}

2.分组功能

先来看看什么是分组,在API 中Pattern这个类介绍是这样描述的:

捕获组可以通过从左到右计算其开括号来编号。例如,在表达式 ((A)(B(C))) 中,存在四个这样的组:

1    

((A)(B(C)))

2    

(A)

3    

(B(C))

4    

(C)

我们可以根据数多少个左括号来确定有多少个组。

下面来代码举例分组的正则表达式用法。

package regex;
 
public class Demo1_Regex {
	
	public static void main(String[] args) {
		// 1叠词:快快乐乐,高高高兴兴
		// 判断字符串是否是上面的叠词规则
		String regex = "(.)\\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));
	}
 
}

那么如何写“快乐快乐”这样叠词的正则表达式呢。这么去分析一下,字符串“快乐快乐”,可以认为“快乐”这个组又出现了一次,结合上面代码提到的知识,我们应该这样写。

package regex;
 
public class Demo1_Regex {
	
	public static void main(String[] args) {
		// 1叠词:快乐快乐
		String regex = "(..)\\1"; 
		System.out.println("快快乐乐".matches(regex));
		System.out.println("快乐快乐".matches(regex));
	}
 
}

练习1:按照叠词进行切割

请按照叠词进行切割“sdqqfgkkkhjppppdk”

package regex;
 
public class Demo1_Split {
 
	public static void main(String[] args) {
		String st = "sdqqfgkkkhjppppkl"; 
		String[] arr = st.split("(.)\\1+");
		
		for (int i = 0; i < arr.length; i++) {
			System.out.println(arr[i]);
		}
	}
}

输出

sd

fg

hj

kl

总结

到此这篇关于Java正则表达式的替换和分组功能的文章就介绍到这了,更多相关Java正则的替换和分组内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!

 类似资料:
  • 问题内容: 我有这个字符串: 现在,我想在每个数字之前添加String num:。 因此结果必须是: 这也必须工作: 用于搜索数字的正则表达式是:[0-9]+ 但是我想用num:+ [匹配的子字符串]替换匹配的子字符串。 我现在写了一个带有数字的示例,但另一个示例可以是:在每个电子邮件地址之前添加 ·Email found·: 问题答案: 利用分组。您可以使用括号(并)定义组,并通过组索引$n在哪

  • 下面就来详细介绍Notepad++中关于正则表达式的部分,主要是查找和替换。 对于替换功能,一般的文本编辑器,都具有此功能,但是对于高级的正则表达式替换,则很多都不支持。而此处Notepad++支持此功能。 正则表达式的替换,在很长一段时间内,我都没有用到过。而后来有此需求的时候,由于不熟悉,导致也没去折腾具体如何使用的。 后来有空去弄了下,终于搞懂了。对此类功能不了解的人,会没啥感觉,但是看了下

  • 问题内容: 有什么方法可以用捕获组的已修改内容替换正则表达式? 例: 我想用$ 1乘以3代替所有出现的情况。 编辑: 看起来好像出了点问题:( 如果我用 引发IllegalStateException:找不到匹配项 但 工作正常,但我不能更改$ 1 :( 问题答案: 要获得第一场比赛,请使用。之后,你可以用来引用此第一个匹配项,并将所有匹配项替换为第一个匹配值乘以3。 如果你想将每个匹配项替换为该

  • 问题内容: 我在Java中使用Rexexp时遇到问题。示例代码写出了,我期望它能输出 我知道replaceAll会替换所有匹配的组,问题是为什么此regexp组在Java中的字符串上匹配两次? 问题答案: 可能会给您“完全匹配”,然后将匹配减少为“空匹配”(但仍然是匹配)。尝试或代替。两者都按预期工作。 在regexinfo中,星的定义如下: *(星号)-将上一个项目重复零次或多次。贪婪,因此在尝

  • 问题内容: 最近,我不得不搜索许多字符串值,以查看哪个字符串与某种模式匹配。在用户输入搜索词之前,字符串值的数量和模式本身都不清楚。问题是,我的应用程序每次运行以下行时,我都已注意到: 大约需要40微秒。不用说,当字符串值的数量超过几千个时,它会太慢。 该模式类似于: 这里的A〜F只是示例,但是模式类似于上面的东西。 请注意 模式实际上每次搜索都会改变。例如,“ A * B * C ”可以更改为W

  • 问题内容: 我有这段代码,我想知道,是否可以替换Java正则表达式中的仅组(不是所有模式)。码: 问题答案: 使用(其中n是数字)来引用中捕获的子序列。我假设您想用文字字符串 “ number” 替换第一组,并用第一组的值替换第二组。 考虑第二组而不是。 是一个贪婪的匹配器,首先会消耗最后一位。当匹配器意识到最终的匹配项时,匹配器将不得不回溯,然后才可以匹配最终的数字。