让我们假设我有以下正则表达式:
-(\d+)-
我想用c#将Group 1 (\d+)替换为AA,得到:
-AA-
现在我用:
var text = "example-123-example";
var pattern = @"-(\d+)-";
var replaced = Regex.Replace(text, pattern, "-AA-");
但我真的不喜欢这样,因为如果我改变模式来匹配_(\d+)_,我将不得不改变替换字符串由_AA_,这是违反DRY原则。
我想要的是:
保持匹配的文本完全是如何,但改变组1的文本和组2的另一个文本…
编辑:
这只是一个例子。我只是在寻找一种通用的方法来做上面所说的事情。
它应该适用于:
任何(\d+)更多的文本和任何你能想象的图案。
我所要做的只是替换组,并保留其余的匹配。
一个好主意是将所有内容封装在组中,不管是否需要标识它们。这样你就可以在替换字符串中使用它们。例如:
var pattern = @"(-)(\d+)(-)";
var replaced = Regex.Replace(text, pattern, "$1AA$3");
或者使用匹配评估器:
var replaced = Regex.Replace(text, pattern, m => m.Groups[1].Value + "AA" + m.Groups[3].Value);
另一种稍微混乱的方法是使用lookbehind/lookahead:
(?<=-)(\d+)(?=-)
执行下面的编码以获得单独的组替换。
new_bib = Regex.Replace(new_bib, @"(?s)(\\bibitem\[[^\]]+\]\{" + pat4 + @"\})[\s\n\v]*([\\\{\}a-zA-Z\.\s\,\;\\\#\\\$\\\%\\\&\*\@\\\!\\\^+\-\\\=\\\~\\\:\\\" + dblqt + @"\\\;\\\`\\\']{20,70})", delegate(Match mts)
{
var fg = mts.Groups[0].Value.ToString();
var fs = mts.Groups[1].Value.ToString();
var fss = mts.Groups[2].Value.ToString();
fss = Regex.Replace(fss, @"[\\\{\}\\\#\\\$\\\%\\\&\*\@\\\!\\\^+\-\\\=\\\~\\\:\\\" + dblqt + @"\\\;\\\`\\\']+", "");
return "<augroup>" + fss + "</augroup>" + fs;
}, RegexOptions.IgnoreCase);