- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要用两个特定符号(@ 和 &)之间的 % 替换所有空格;喜欢以下内容:
'this @ is test &that did not @turn& out well'
应转换为
'this @%is%test%&that did not @turn& out well'
和
'@pattern matching& is my number one enemy'
到
'@pattern%matching& is my number one enemy'
我几乎阅读了 stackoverflow 和其他站点中的所有相关问题,但无法获得有用的答案。
最佳答案
执行此操作的一种(低效)方法是执行多次 REGEXP_REPLACE
调用。
例如,让我们看一下下面的plpgsql
函数。
CREATE OR REPLACE FUNCTION replaceSpacesBetweenTwoSymbols(startChar TEXT, endChar TEXT, textToParse TEXT)
RETURNS TEXT
AS $$
DECLARE resultText TEXT := textToParse;
DECLARE tempText TEXT := textToParse;
BEGIN
WHILE TRUE LOOP
tempText = REGEXP_REPLACE(resultText,
'(' || startChar || '[^' || endChar || ']*)' || '( )(.*' || endChar || ')',
'\1%\3');
IF tempText = resultText
THEN RETURN resultText;
END IF;
resultText := tempText;
END LOOP;
RETURN resultText;
END;
$$
LANGUAGE 'plpgsql';
我们创建了一个接受三个参数的函数,startChar
、endChar
和保存将被修剪的文本的textToParse
。
我们首先创建一个基于startChar
和endChar
的正则表达式。如果 startChar
的值为 @
并且 endChar
的值为 &
我们将得到以下正则表达式:
(@[^&]*)( )(.*&)
这个正则表达式由三组组成:
(@[^&]*)
- 该组匹配 @ 和空格字符之间的文本 - ' ';
( )
- 该组匹配单个空格字符。
(.*&)
- 该组匹配空格字符和 &
字符之间的文本。
为了替换空格(第 2 组),我们使用以下 REGEXP_REPLACE
调用:
REGEXP_REPLACE(resultText,' (@[^&]*)( )(.*&)', '\1%\3')
从该表达式中,您可以看到我们正在用 %
字符替换第二组(这是一个空格)。
这样,每次执行 REGEXP_REPLACE
时,我们只会替换一个空格。一旦我们发现没有更多的空格需要替换,我们返回修改后的TEXT
。
此时,空格被替换为%
字符。我们需要做的最后一件事是用单个 %
替换多个连续的 %
字符。
这可以通过最后调用另一个 REGEXP_REPLACE
来完成。例如:
SELECT REGEXP_REPLACE(replaceSpacesBetweenTwoSymbols('@','&','this @ is test &that did not @turn& out well'),'%{2,}','%');
会回来
this @%is%test%&that did not @turn& out well
结果,虽然这
SELECT REGEXP_REPLACE(replaceSpacesBetweenTwoSymbols('@','&','this is @a more complex& task @test a a & w'),'%{2,}','%');
会回来
this is @a%more%complex& task @test%a%a%& w
结果。
关于postgresql - REGEXP_REPLACE 替换两个符号之间的空格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54098290/
我想对一个字符串执行搜索和替换,比如 password。 正如您从问题中了解到的那样,替换后的字符串应变为 sdvvzrug。 但不幸的是,下面的代码输出bbbbcaab: $search = ran
我正在使用 futurize --stage2它应用了许多源代码转换以使代码 python2 和 python3 兼容。其中一个修复是所有分区 a/b 都替换为 old_div(a/b),我想避免这种
我正在使用 RStudio,但我在控制台上的输出被截断了。我找不到如何停止截断(我尝试搜索 ?options 以及在谷歌上搜索的时间比我想承认的要长)。 编辑:我向大家道歉!我最初的长名称为“This
我有一个 fragment 堆栈,我在其中使用替换和相加。添加或替换我的 fragment 的代码(在我的 Activity 中)如下 private fun addFragment(fragment
我在一个数组中插入了一些字符串,但在我这样做之前,我想按照主题所说的去做。只用 %20 替换空格,我这样做: Name.push(linkText.replace(" ", "%20")); 但是我如
我正在尝试编译和测试我在网上看到的代码 Expanding an IP add 。但是,当我尝试编译它时,我收到有关 StringBuilder 替换方法的错误。它说: IPadd.java:52:
我正在尝试使用 dplyr 的最新功能重写我的部分代码,方法是将 data.frame() 替换为 data_frame() 和 cbind() 与 bind_cols(): library(rgeo
我最近偶然发现了 replace()和 "[ x.tst s.tst s.tst [,1] [,2] [,3] [1,] 0 0 0
我一直想知道,如何在给定的参数内进行替换。 如果你有这样的一行: 123,Hello,World,(I am, here), unknown 你想更换 World与 Foobar那么这是一个简单的任务
如何转义字符串中的双引号?例如, input: "Nobody" output: \"Nobody\" 我尝试过这样的操作,但不起作用: String name = "Nobody"; name.r
我正在做类似的事情: SQL sql sQl SqL var ps = document.getElementsByTagName('p'); for(var i = 0; i 但它不会替换文本。
我正在尝试用 \" 替换所有 " 并用 JSON 解析字符串,但浏览器抛出错误 SyntaxError: JSON Parse error: Unrecognized token '\'. 下面是代码
大家好,在这里挣扎...... 是否可以将第一个正斜杠之间的任何内容替换为“”,但保留其余部分? 例如var 将是 string "/anything-here-this-needs-to-be-re
在下面的代码中,JavaScript 替换函数中的 alert(a) 将提醒匹配的字符串,在本例中,将是 {name} 和 {place}。 这按照文档 javascript docs 的描述工作,即
+-----------------------------+ | tables | +-------------------
我正在尝试用\"替换包含 "的字符串,下面是我尝试过的程序 String s="\"/test /string\""; s = s.replaceAll("\"", "\\\"");
var text = "a's ..a's ...\"... "; text = convert(text); function convert( text ) { var n = text
我正在尝试使用 JavaScript 中的替换函数,但有一个问题。 strNewDdlVolCannRegion = strNewDdlVolCannRegion.replace(/_existing
好吧,首先我对我的上一篇文章感到非常抱歉,但我真的需要帮助,我会把我真正想要的东西放在一个更清晰的代码中。我不擅长 javascript,所以希望你能帮助我。
我正在写一张纸条,遇到了障碍。可能有更有效的方法来执行此操作,但我对 Python 还很陌生。我正在尝试创建用户生成的 IP 地址列表。我正在使用 print 来查看生成的值是否正确。当我运行此代码时
我是一名优秀的程序员,十分优秀!