正则表达式 - 替换多次出现

Posted

技术标签:

【中文标题】正则表达式 - 替换多次出现【英文标题】:regex - Replace multiple occurrences 【发布时间】:2018-10-04 19:27:15 【问题描述】:

我有一个字符串,可以是以下任何一种情况:

    test1/test2/test3/test4/test5/ test1/test2/test3/test4// test1/test2/test3/// test1/test2//// test1/////

我的预期结果是

    test1/test2/test3/test4/test5

    test1/test2/test3/test4

    test1/test2/test3

    test1/test2 测试1 如何使用正则表达式实现?

目前,我正在使用 regexp_replace(col, "/+/", "/") 它正在工作,但最后留下了一个额外的 /。

【问题讨论】:

/处拆分,过滤掉数组中的空字符串,加入/ my answer 有帮助吗? 【参考方案1】:

你可以使用

regexp_replace(col, '/+$|(/)2,', '\\1')

请参阅regex demo。

详情

/+$ - 字符串末尾有 1 个或多个 / | - 或 (/)2, - 两个或多个斜杠,其中最后一个将保存在捕获组 1 中,您可以使用 \1 占位符从替换模式中引用它。

【讨论】:

【参考方案2】:

您可以使用以下正则表达式:

/\/+$/gm

并替换为空字符串 ('')。

正则表达式将匹配字符串末尾的一个或多个斜杠,然后将其替换为空字符串,这意味着路径将不再以斜杠结尾。

【讨论】:

以上是关于正则表达式 - 替换多次出现的主要内容,如果未能解决你的问题,请参考以下文章

Oracle 正则表达式替换用逗号包围的字符串的多次出现

正则表达式 - 替换多次出现

如何使用正则表达式进行多次替换?

正则表达式替换除大小写“0”之外的所有花括号

2021-05-08

一个可以使用多个正则表达式进行多次尝试匹配,并进行替换的Excel VBA自定义函数(UFD)