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)
我想知道是否有人可以提供一些更好的算法的提示,这些算法可以更好地处理大块文本?我正在考虑使用一个字符串构建器,但我也想到我可能会以完全错误的方式接近它.任何见解将不胜感激.
正则表达式将完成这项工作,代码应该更简单.但是,您需要进行测试以确定它是否确实提供了更好的性能.像这样的东西:
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)
归档时间: |
|
查看次数: |
716 次 |
最近记录: |