小编典典

REGEXP_REPLACE-仅在()中包含的情况下,才从字符串中删除新行\ n

sql

我正在尝试使用REGEXP_REPLACE替换字符串中的所有新行(\ n),但有一个例外-它们必须括在要替换的括号中。

例子:

在字符串之前:

'a\n, b\n, c (a\n, b, c\n), d\n, e'
var1 := 'a
, b
, c (a
, b, c
), d
, e'

字符串后:

'a\n, b\n, c, (a b c), d\n, e'
var2 := 'a
, b
, c (a, b, c), d
, e'

我知道必须有一个干净的正则表达式模式可以做到这一点-但我无法回避它。

非常感谢…


阅读 157

收藏
2021-04-28

共1个答案

小编典典

var2 := regexp_replace(var1, '((\)|^).*?(\(|$))|'||chr(10), '\1', 1, 0, 'n');
2021-04-28