Java正则表达式匹配aabb、abab格式字符

createh53个月前 (02-01)技术教程13

我们开发过程中,经常用到正则表达式来匹配想要的字符串,或者从一段文本中提取想要的关键字,比如爬虫应用等。正则表达式是对字符串提取的一套规则,我们把这个规则用正则里面的特定语法表达出来,去匹配满足这个规则的字符串。正则表达式具有通用型,不仅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这类格式的字符串会让人想起学过的成语,比如:急急忙忙,坑坑洼洼,风风火火,彼此彼此,动次动次,哇凉哇凉。
那么我们就来通过正则表达式来匹配这一类的字符串。

//匹配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"这种类型的字符串呢,比如:“相亲相爱,绘声绘色,不吐不快” 这一类型的成语,与上面类似,实现代码如下:

//匹配abac类型字符串
????????p?=?Pattern.compile("^(.).\\1.$");
????????m=p.matcher("相亲相爱");
????????System.out.println("匹配abac类型字符串:相亲相爱?"+?m.matches());

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

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


相关文章

100个Java工具类之70:字符串处理工具类StringUtils

StringUtils是常用的工具类,提供大量处理字符串的静态方法。StringUtils主要特点对null安全:如入参是null,方法不会抛出NullPointerException,而会返回相应的...

MySql字符串拆分实现split功能(字段分割转列、转行)

字符串转多行字符串拆分: SUBSTRING_INDEX(str, delim, count)替换函数:replace( str, from_str, to_str)获取字符串长度:LENGTH( s...

Java代码审计之SpEL表达式注入(spring的setter注入)

SpEL 表达式注入Spring Expression Language(简称 SpEL)是一种功能强大的表达式语言、用于在运行时查询和操作对象图;语法上类似于 Unified EL,但提供了更多的特...

二、Java字符串/时间处理(java字符串时间格式转换)

二、Java字符串/时间处理1、 文章背景工作已有五年之久,回望过去,没有在一线城市快节奏下学习成长,只能自己不断在工作中学习进步,最近一直想写写属于自己的文章,记录学习的内容和知识点,当做一次成长。...

Easysearch Java SDK 2.0.x 使用指南(三)

在 Easysearch Java SDK 2.0.x 使用指南(一) 中,我们介绍了 Easysearch Java SDK 2.0.2 的基本使用和批量操作功能。在 Easysearch Java...

mysql拼接函数讲解及配合截取函数使用

在上一篇我们讲解了mysql的截取函数用法。本篇我们将讲解mysql的拼接函数以及配合截取函数实现当留言数字过多省略显示的场景。concat函数:把参数连成一个长字符串并返回(任何参数是NULL时返回...