Java正则表达式匹配AABB、ABAB格式字符

2023-03-27 23:19:00 浏览数 (1)

我们开发过程中,经常用到正则表达式来匹配想要的字符串,或者从一段文本中提取想要的关键字,比如爬虫应用等。正则表达式是对字符串提取的一套规则,我们把这个规则用正则里面的特定语法表达出来,去匹配满足这个规则的字符串。正则表达式具有通用型,不仅java里面可以用,其他的语言也一样适用。

1. 正则表达式基本字符

在这里插入图片描述在这里插入图片描述

2. Java正则常用类Pattern类与Matcher类

Pattern类用于创建一个正则表达式,也可以说创建一个匹配模式:

Pattren p = Pattren.compile("d ");

Matcher不能随意创建,只能通过Pattern.matcher(CharSequence input)方法得到该类的实例。

Matcher m=p.matcher("4352");

m.matches();

3. 匹配aabb、abab格式字符串

看到aabb、abab这类格式的字符串会让人想起学过的成语,比如:急急忙忙,坑坑洼洼,风风火火,彼此彼此,动次动次,哇凉哇凉。

那么我们就来通过正则表达式来匹配这一类的字符串。

代码语言:java复制
//匹配aabb类型字符串
Pattern p = Pattern.compile("^(.)\1(.)\2$");
Matcher m=p.matcher("急急忙忙");
System.out.println("匹配aabb类型字符串:急急忙忙 "  m.matches());

//匹配abab类型字符串
p = Pattern.compile("^(.)(.)\1\2$");
m=p.matcher("彼此彼此");
System.out.println("匹配abab类型字符串:彼此彼此 "  m.matches());

解释一下,首先“^”和“$”大家都比较熟悉,表示开头和结尾。

那么“(.)”代表什么含义呢?“.”表示匹配任意字符,“(.)”表示匹配任意字符的一个分组,如果出现多个括号,就有多个分组,“1”表示引用第一个分组,“2”引用第二个分组,依次类推。所以,"^(.)1(.)2$" 这个表达式表示的意思就是,第一个字符出现后,在第二个位置又被引用,也就是第一和第二位置的字符一样,同样,“(.)2” 就是第二个分组的字符也被再引用一次,这样就能匹配"aabb"格式的字符串了。

接下来,如果要匹配"abac"这种类型的字符串呢,比如:“相亲相爱,绘声绘色,不吐不快” 这一类型的成语,与上面类似,实现代码如下:

代码语言:java复制
//匹配abac类型字符串
        p = Pattern.compile("^(.).\1.$");
        m=p.matcher("相亲相爱");
        System.out.println("匹配abac类型字符串:相亲相爱 "  m.matches());

是不是很简单,希望大家自己多练习,这样就可以轻松掌握这一类正则表达式的匹配方法了。

更多技术资源、软件开发工具,欢迎访问【昂焱数据】,这里一定有惊喜等着你!

0 人点赞