当前位置: 代码网 > it编程>编程语言>正则表达式 > 正则表达式regexp_replace的使用方法

正则表达式regexp_replace的使用方法

2024年05月18日 正则表达式 我要评论
前言regexp_replace的使用非常灵活,且容易忘记,故做此笔记。 没有过多的介绍使用说明,只是根据个人理解列出很多相似案例,个人觉得通过对比,更容易理解几个参数的使用技巧。所有案例均是实跑出来

前言

regexp_replace的使用非常灵活,且容易忘记,故做此笔记。 没有过多的介绍使用说明,只是根据个人理解列出很多相似案例,个人觉得通过对比,更容易理解几个参数的使用技巧。

所有案例均是实跑出来的结果。

带颜色的部分是需要留意的地方。

命令格式:

 regexp_replace(source, pattern, replace_string, occurrence)

参数说明:

● source: string类型,要替换的原始字符串。

● pattern: string类型常量,要匹配的正则模式,pattern为空串时抛异常。

● replace_string:string,将匹配的pattern替换成的字符串。

● occurrence: bigint类型常量,必须大于等于0,

大于0:表示将第几次匹配替换成replace_string,

等于0:表示替换掉所有的匹配子串。

其它类型或小于0抛异常。

返回值:

将source字符串中匹配pattern的子串替换成指定字符串后返回,当输入source, pattern, occurrence参数为null时返回null,若replace_string为null且pattern有匹配,返回null,replace_string为null但pattern不匹配,则返回原串。

常用案例

1、用’#‘替换字符串中的所有数字

select regexp_replace('01234abcde56789','[0-9]','#') as new_str from dual;

结果:#####abcde#####

用’#‘替换字符串中的数字0、9

select regexp_replace(‘01234abcde56789','[09]','#') as new_str from dual;

结果:#1234abcde5678#

2、遇到小写字母或者数字跳过,从匹配到的第4个值开始替换,替换为''

select regexp_replace('abcdefg123456abc','[a-z0-9]','',4)

结果:abcefg123456abc

select regexp_replace('abcdefg123456abc','[a-z0-9]','',4)

结果:abcdeg123456abc

select regexp_replace('abcdefg123456abc','[a-z0-9]','',7);

结果:abcdefg13456abc

遇到非小写字母或者数字跳过,将所有匹配到的值替换为''

select regexp_replace('abcdefg123456abc','[a-z0-9]','',0);

结果:dabc

3、格式化手机号,将+86 13811112222转换为(+86) 138-1111-2222,’+‘在正则表达式中有定义,需要转义。\\1表示引用的第一个组
select regexp_replace('+86 13811112222','(\\+[0-9]{2})( )([0-9]{3})([0-9]{4})([0-9]{4})','(\\1)\\3-\\4-\\5',0);

结果:(+86)138-1111-2222

select regexp_replace("123.456.7890","([[:digit:]]{3})\\.([[:digit:]]{3})\\.([[:digit:]]{4})","(\\1)\\2-\\3",0) ;
select regexp_replace("123.456.7890","([0-9]{3})\\.([0-9]{3})\\.([0-9]{4})","(\\1)\\2-\\3",0) ;

结果:(123)456-7890

4、将字符用空格分隔开,0表示替换掉所有的匹配子串。

      select regexp_replace('abcdefg123456abc','(.)','\\1 ',0) as new_str from dual;

结果:a b c d e f g 1 2 3 4 5 6 a b c

      select regexp_replace('abcdefg123456abc','(.)','\\1 ',2) as new_str from dual;

结果:ab cdefg123456abc

5、

select regexp_replace("abcd","(.*)(.)$","\\1",0) ;

结果:abc

select regexp_replace("abcd","(.*)(.)$","\\2",0) ;

结果:d

select regexp_replace("abcd","(.*)(.)$","\\1-\\2",0) ;

结果:abc-d

其他案例:

select regexp_replace("abcd","(.)","\\2",1) 结果为"abcd",因为pattern中只定义了一个组,引用的第二个组不存在。
select regexp_replace("abcd","(.*)(.)$","\\2",0) 结果为"d"
select regexp_replace("abcd","(.*)(.)$","\\1",0) 结果为"abc"
select regexp_replace("abcd","(.*)(.)$","\\1-\\2",0) 结果为"abc-d"
select regexp_replace("abcd","a","\\1",0),结果为” \1bcd”,因为在pattern中没有组的定义,所以\1直接输出为字符。

正则符号释义:

总结

到此这篇关于正则表达式regexp_replace使用的文章就介绍到这了,更多相关regexp_replace使用方法内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com