在C#中在令牌之前和之后插入文本的最佳算法?

Ale*_*ort 1 c# search highlight

我正在研究MVC C#应用程序的搜索功能,该应用程序将通过过滤器放置一个(可能很大的)大量文本,并且在给定搜索查询的情况下,将<span>在每个搜索项之前和之后放置带有突出显示样式的html .

我有一个简单的算法,但我觉得它会很慢,可能是因为需要创建的字符串数量(2*匹配数).

public static string Surround(string original, string head, string tail, string match, StringComparison comparer)
{
    var ret = original;

    if (ret.IndexOf(match, 0, comparer) != -1)
    {
        var lastIndex = 0;

        while ((lastIndex = ret.IndexOf(match, lastIndex, comparer)) != -1)
        {
            ret = ret.Insert(lastIndex, head);
            var tailIndex = lastIndex + match.Length + head.Length;
            lastIndex = tailIndex;
            ret = ret.Insert(tailIndex, tail);
        }
    }

    return ret;
}
Run Code Online (Sandbox Code Playgroud)

我想知道是否有人可以提供一些更好的算法的提示,这些算法可以更好地处理大块文本?我正在考虑使用一个字符串构建器,但我也想到我可能会以完全错误的方式接近它.任何见解将不胜感激.

Luk*_*keH 6

正则表达式将完成这项工作,代码应该更简单.但是,您需要进行测试以确定它是否确实提供了更好的性能.像这样的东西:

public static string Surround(
    string original, string head, string tail, string match)
{
    return Regex.Replace(
        original, match, head + "$0" + tail, RegexOptions.IgnoreCase);
}
Run Code Online (Sandbox Code Playgroud)

如果您可以在保存2N字符串会话时传入整个替换器,那就更好了:

public static string Surround(string original, string replacer, string match)
{
    return Regex.Replace(original, match, replacer, RegexOptions.IgnoreCase);
}

Surround("foo bar baz", "<span>$&</span>", "bar");  //call like so
Run Code Online (Sandbox Code Playgroud)