如何解决记事本++正则表达式查找并替换括号之间的空格
在记事本++中,想改变这个:
[City tier] [nvarchar](max) NULL,[Counting unit] [nvarchar](max) NULL,
为此:
[City_tier] [nvarchar](max) NULL,[Counting_unit] [nvarchar](max) NULL,
我已经使用 [\w+(\s)\w+] 来定位这两条记录,但是当我使用 \1_ 替换时,我得到了
_ [nvarchar](max) NULL,_ [nvarchar](max) NULL,
解决方法
您可以使用此 PCRE 正则表达式进行搜索:
((?:\[|(?!^)\G)[^]\s]*)\s
并替换为:
$1_
正则表达式详情:
-
(
:开始捕获组 #1-
(?:
:启动非捕获组-
\[
:匹配一个[
-
|
:或 -
(?!^)\G
:从上一场比赛的结尾重新开始匹配
-
-
)
:结束非捕获组 -
[^]\s]*
:匹配 0 个或多个非空白字符和非]
-
-
)
:结束捕获组 #1 -
\s
:匹配一个空格
Notepad++ 支持 \G
和 \K
允许您使用
(?:\G(?!\A)|\[)[^][\s]+\K\s+
这需要用下划线代替,参见a demo on regex101.com。
这归结为
(?: # non-capturing group (?:...)
\G(?!\A) # match after the last match but not at the very start
| # or
\[ # a "[" literally
)
[^][\s]+\K # not "]" nor "[" nor spaces,\K -> "forget everything on the left"
\s+ # whitespace characters
实际上,此构造仅匹配方括号内的空格。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。