我希望在Sublime Text 2中用正则表达式做搜索替换。关于这方面的文档相当贫乏。具体来说,我想在组上做一个替换,比如转换这个文本:

你好,我叫鲍勃

这个搜索词是:

我的名字是(\w)+

替换为:my name used to be $(1)

搜索词工作得很好,但我想不出使用regexp组实际执行替换的方法。


当前回答

我也遇到过类似的问题:

很多条纹都是这样的 Don Jos6去了(正确的是Don José去了)

我使用了这个工具: https://coding.tools/regex-replace

正则表达式:([a-z]

替换为:$1é

点击“Regex Replace”按钮。 结果:

Don José去了

它也适用于谷歌表。

其他回答

以下是已批准答案的可视化演示。

注意,如果您使用超过9个捕获组,则必须使用语法${10}。

$10或\10或\{10}都不行。

我也遇到过类似的问题:

很多条纹都是这样的 Don Jos6去了(正确的是Don José去了)

我使用了这个工具: https://coding.tools/regex-replace

正则表达式:([a-z]

替换为:$1é

点击“Regex Replace”按钮。 结果:

Don José去了

它也适用于谷歌表。

通常,对于第一个捕获组(括号中模式的第一个匹配),反向引用是$1或\1(反斜杠1),实际上Sublime支持这两种语法。所以尝试:

my name used to be \1

or

my name used to be $1

还要注意您原始的捕获模式:

my name is (\w)+

是不正确的,将只捕获名称的最后一个字母,而不是整个名称。您应该使用以下模式来捕获名称的所有字母:

my name is (\w+)

顺便说一下,在上面的问题中:

For:

Hello, my name is bob

发现部分:

my name is (\w)+

带更换部分:

my name used to be \1

将返回:

Hello, my name used to be b

更改查找部分为:

my name is (\w+)

取而代之的将是你所期望的:

Hello, my name used to be bob

虽然(\w)+将匹配“bob”,但它不是你想要替换的分组。