JavaScript 回溯正则表达式

javascript lookback regex

本文关键字:正则表达式 回溯 JavaScript      更新时间:2023-09-26

我想替换字符串中所有前面没有_数字1的字母。

所以

jj*_sin(jj)+_cos(hh)

应该是

1*_sin(1)+_cos(1)

如何使用正则表达式回溯或任何其他方法实现它。

使用如下所示的负面前瞻断言。

(?!_)'b[a-z]+

然后将匹配的字符替换为1

演示

> "jj*_sin(jj)+_cos(hh)".replace(/(?!_)'b[a-z]+/g, "1")
'1*_sin(1)+_cos(1)'

var str = "jj*_sin(jj)+_cos(hh)";
snippet.log("Before: " + str);
str = str.replace(/(^|[^_])'b[a-z]+/g, "$11");
snippet.log("After:  " + str);
<!-- Script provides the `snippet` object, see http://meta.stackexchange.com/a/242144/134069 -->
<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>

'b单词边界是上述正则表达式中的重要内容,它在单词字符和非单词字符之间匹配。 (^|[^_])捕获行的开头或非下划线的字符。 'b在这里很重要,因为如果没有'b,它将匹配像这样的字符串9foo'b确保字母表前面有非单词字符或起始锚点。 [a-z]+匹配一个或多个小写字母。因此,通过将所有匹配的字符替换为组索引 1 内的字符加上一个数字1将为您提供所需的输出。

你可以

String#replace和正则表达式来做到这一点,但正如nhahtdh在评论中指出的那样,它很可能只能让你走到这一步。你最好构建一个解析器,可能使用 Jison 或任何其他解析器生成器。

执行此操作的方法是使用捕获组和回调函数:

var str = "jj*_sin(jj)+_cos(hh)";
snippet.log("Before: " + str);
str = str.replace(/(_?)([a-zA-Z]+)/g, function(m, c0, c1) {
  return c0 === "_" ? m : c0 + "1";
});
snippet.log("After:  " + str);
<!-- Script provides the `snippet` object, see http://meta.stackexchange.com/a/242144/134069 -->
<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>

1*_sin(1)+_cos(1)

var str = "jj*_sin(jj)+_cos(hh)";
snippet.log("Before: " + str);
str = str.replace(/(_?)([a-zA-Z]+)/g, function(m, c0, c1) {
  return c0 === "_" ? m : c0 + "1";
});
snippet.log("After:  " + str);
<!-- Script provides the `snippet` object, see http://meta.stackexchange.com/a/242144/134069 -->
<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>