使用正则表达式复制选择并替换一些字符
Using regex to duplicate a selection and replacing some characters
可能是个糟糕的标题。
我正在尝试采取以下措施:
Joe Dane
Bob Sagget
Whitney Houston
Some
Other
Test
并尝试生产:
JOE_DANE("Joe Dane"),
BOB_SAGGET("Bob Sagget"),
WHITNEY_HOUSTON("Whitney Houston"),
SOME("Some"),
OTHER("Other"),
TEST("Test"),
我正在使用 Notepad++,我很接近,但在正则表达式方面还不够好,无法计算出剩余的表达式。到目前为止,这就是我所拥有的:
查找内容:(^.*)
替换为: \(\"\"\),
产生:Joe Dane("Joe Dane"),
我试过替换为:\U \(\"\"\),
但这也会影响 </code> 的第二个大写实例。它也不会用下划线 <code>_
.
替换空格
您可以分两步完成,首先从字符串的开头匹配任何字符 1 次以上。
找什么
^.+
第一次替换可以使用\E
结束激活\U
,使用全匹配[=15=]
替换为
\U[=11=]\E\("[=11=]"\),
第二步,要用下划线替换空格,你可以跳过括号之间的文本,匹配大写字符之间的空格。
找什么
\(".*?"\)(*SKIP)(*F)|[A-Z]+\K\h+(?=[A-Z])
\(".*?"\)
匹配从 ("
到 ")
(*SKIP)(*F)|
跳过这部分比赛
[A-Z]+\K
匹配大写字符并使用\K
清空当前匹配缓冲区(忘记matches做了什么)
\h+(?=[A-Z])
匹配 1+ 个水平空白字符并在右侧声明一个大写字符
替换为 _
这可以一步完成。
如果一行中的字数不超过 2 个:
- Ctrl+H
- 查找内容:
^(\S+)(?: (\S+))?$
- 替换为:
\U(?2_)\E\("[=13=]"\),
- 检查 环绕
- 检查 正则表达式
- 全部替换
解释:
^ # beginning of line
(\S+) # group 1, 1 or more non space
(?: (\S+))? # non capture group, a space, group 2, 1 or more non space, optional
$
替换:
\U # uppercased
# group 1
(?2_) # if group 2 exists, add and underscore before
\E # end uppercase
\("[=11=]"\), # the whole match with parens and quote
截图(后):
如果您的字数超过 2 个(最多 5 个),请使用:
查找^(\S+)(?: (\S+))?(?: (\S+))?(?: (\S+))?(?: (\S+))?
替换:\U(?2_)(?3_)(?4_)(?5_)\E\("[=15=]"\),
我有五个以上的字,需要多少就加多少(?: (\S+))?
。
可能是个糟糕的标题。
我正在尝试采取以下措施:
Joe Dane
Bob Sagget
Whitney Houston
Some
Other
Test
并尝试生产:
JOE_DANE("Joe Dane"),
BOB_SAGGET("Bob Sagget"),
WHITNEY_HOUSTON("Whitney Houston"),
SOME("Some"),
OTHER("Other"),
TEST("Test"),
我正在使用 Notepad++,我很接近,但在正则表达式方面还不够好,无法计算出剩余的表达式。到目前为止,这就是我所拥有的:
查找内容:(^.*)
替换为: \(\"\"\),
产生:Joe Dane("Joe Dane"),
我试过替换为:\U \(\"\"\),
但这也会影响 </code> 的第二个大写实例。它也不会用下划线 <code>_
.
您可以分两步完成,首先从字符串的开头匹配任何字符 1 次以上。
找什么
^.+
第一次替换可以使用\E
结束激活\U
,使用全匹配[=15=]
替换为
\U[=11=]\E\("[=11=]"\),
第二步,要用下划线替换空格,你可以跳过括号之间的文本,匹配大写字符之间的空格。
找什么
\(".*?"\)(*SKIP)(*F)|[A-Z]+\K\h+(?=[A-Z])
\(".*?"\)
匹配从("
到")
(*SKIP)(*F)|
跳过这部分比赛[A-Z]+\K
匹配大写字符并使用\K
清空当前匹配缓冲区(忘记matches做了什么)\h+(?=[A-Z])
匹配 1+ 个水平空白字符并在右侧声明一个大写字符
替换为 _
这可以一步完成。
如果一行中的字数不超过 2 个:
- Ctrl+H
- 查找内容:
^(\S+)(?: (\S+))?$
- 替换为:
\U(?2_)\E\("[=13=]"\),
- 检查 环绕
- 检查 正则表达式
- 全部替换
解释:
^ # beginning of line
(\S+) # group 1, 1 or more non space
(?: (\S+))? # non capture group, a space, group 2, 1 or more non space, optional
$
替换:
\U # uppercased
# group 1
(?2_) # if group 2 exists, add and underscore before
\E # end uppercase
\("[=11=]"\), # the whole match with parens and quote
截图(后):
如果您的字数超过 2 个(最多 5 个),请使用:
查找
^(\S+)(?: (\S+))?(?: (\S+))?(?: (\S+))?(?: (\S+))?
替换:
\U(?2_)(?3_)(?4_)(?5_)\E\("[=15=]"\),
我有五个以上的字,需要多少就加多少(?: (\S+))?
。