Kotlin利用Regex如何构建正则表达式详解
前言
对于正则表达式,相信很多人都知道,但是很多人的第一感觉就是难学,因为看第一眼时,觉得完全没有规律可寻,而且全是一堆各种各样的特殊符号,完全不知所云。
其实只是对正则不了解而以,了解了你就会发现,原来就这样啊~~正则所用的相关字符其实不多,也不难记,更不难懂,唯一难的就是组合起来之后,可读性比较差,而且不容易理解,最近在学习kotlin,Kotlin 提供了一个正则表达式类 Regex,下面来一起学习下吧。
Regex 提供了丰富而简单实用的函数。
函数名称 | 功能说明 |
---|---|
matches(input: CharSequence): Boolean | 输入字符串全部匹配 |
containsMatchIn(input: CharSequence): Boolean | 输入字符串至少有一个匹配 |
matchEntire(input: CharSequence): MatchResult? | 输入字符串全部匹配,返回一个匹配结果对象 |
replace(input: CharSequence, replacement: String): String | 把输入字符串中匹配的部分替换成replacement的内容 |
replace(input: CharSequence, transform: (MatchResult) -> CharSequence): String | 把输入字符串中匹配到的值,用函数 transform映射之后的新值替换 |
find(input: CharSequence, startIndex: Int = 0): MatchResult? | 返回输入字符串中第一个匹配的值 |
findAll(input: CharSequence, startIndex: Int = 0): Sequence<MatchResult> | 返回输入字符串中所有匹配的值MatchResult的序列 |
matches
输入的字符串全部匹配“正则表达式”返回 true,否则返回 false。
val r1 = Regex("[a-z]+") println(r1.matches("ABCdef")) val r2 = Regex("[a-z]+", RegexOption.IGNORE_CASE) //忽略大小写 println(r2.matches("ABCdef")) val r3 = Regex("[A-Z]+") println(r3.matches("ABC")) val r4 = "[A-Z]+".toRegex() println(r4.matches("ABCDEFXYZ"))
运行结果
false true true true
containsMatchIn
输入的字符串中至少有一个匹配就返回 true,否则就返回 false。
val r5 = Regex("[0-9]+") println(r5.containsMatchIn("012abdc")) println(r5.containsMatchIn("JAVAI"))
运行结果
true false
matchEntire
对字符串全部做比较,都匹配正则表达式返回一个MatcherMatchResult对象,否则返回 null。
val r6 = Regex("[0-9]+") println(r6.matchEntire("1234567890")) println(r6.matchEntire("1234567890!")) println(r6.matchEntire("1234567890")?.value)
当我们使用 MatcherMatchResult 的 value 值来显示匹配结果,由于 matchEntire 函数有可能返回一个 null,所以这里使用了安全调用符号“?”。
运行结果
kotlin.text.MatcherMatchResult@1fb3ebeb null 1234567890
replace
replace(input: CharSequence, replacement: String): String
输入的字符串匹配的部分替换成 replacement 的内容。
val r7 = Regex("[0-9]+") println(r7.replace("12345XYZ33", "abcd"))
这个例子是把数字替换成了 abcd。
replace函数
函数签名 replace(input: CharSequence, transform: (MatchResult)->CharSequence): String
它的功能是把输入的字符串中匹配的值,用函数 transform 映射之后的新值进行替换。
val r8 = Regex("[0-9]+") println(r8.replace("12XYZ9", {(it.value.toInt() * it.value.toInt()).toString()}))
我们可以看到,输入的字符串中有两个数字,一个是 12 在字符串的前部,一个是 9 在字符串的后部。
运行结果
144XYZ81
12 被替换成了 144,9 被替换成了 81。
find函数
返回字符串中第一个匹配的 MatcherMatchResult 对象
val r9 = Regex("[0-9]+") println(r9.find("123ADPOIW87WEERUU005")) println(r9.find("123ADPOIW87WEERUU005")?.value)
这段代码,会匹配123,而使用了 value 值的方式显示出的结果,我们更加容易理解。
运行结果
kotlin.text.MatcherMatchResult@1fb3ebeb 123
findAll
返回输入的字符串中所有匹配的值的 MatchResult 序列。
我们可以通过 forEach 循环遍历显示所有匹配结果
val src2 = "电话:010-12345678;传真:010-10171695;备用:010-20141017" val re2 = """(\d{3}-\d{8})""" //"\\d{3}-\\d{8}" Regex(re2).findAll(src2).forEach { println(it.value + " 位置:[" + it.range + "]") }
运行结果
010-12345678 位置:[3..14] 010-10171695 位置:[19..30] 010-20141017 位置:[35..46]
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
相关文章
Android ExpandableListView单选以及多选实现代码
这篇文章主要为大家详细介绍了Android ExpandableListView单选以及多选的实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-06-06解决android.support.v4.content.FileProvide找不到的问题
这篇文章主要介绍了解决android.support.v4.content.FileProvide找不到的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-03-03Android SwipeRefreshLayout下拉刷新组件示例
SwipeRefrshLayout是Google官方更新的一个Widget,可以实现下拉刷新的效果。本文主要介绍了Android之SwipeRefreshLayout下拉刷新组件示例,有兴趣的可以了解一下。2017-02-02Android使用CountDownTimer实现倒数定时器效果
这篇文章主要介绍了Android使用CountDownTimer实现倒数定时器效果的资料,这里整理了详细的代码,有需要的小伙伴可以参考下。2017-02-02Android利用FlexboxLayout轻松实现流动布局
flexbox是属于CSS的一种布局方案,可以简单、完整、响应式的实现各种页面布局。谷歌将其引入以提高复杂布局的能力。下面这篇文章主要给大家介绍了在Android中利用FlexboxLayout轻松实现流动布局的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。2017-04-04
最新评论