使用正则表达式复制选择并替换一些字符

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+))?