如果你将通过许多字符串循环,那么也许正则表达式可能不是最好的主意 - 这是一个伟大的工具,但不是最快的。
下面是一个示例代码,也将工作:
var str = "The Cat ate a mouse";
var search = "cat";
var index = str.IndexOf(search, StringComparison.CurrentCultureIgnoreCase);
if (index == -1)
throw new Exception("String not found"); //or do something else in this case here
var newStr = str.Substring(0, index) + "{" + str.Substring(index, search.Length) + "}" + str.Substring(index + search.Length);
编辑:
正如评论指出的,上面的代码有一些问题。
因此,我决定尝试找到一种方法使其工作,而不使用正则表达式。不要误解我的意思,我喜欢Regex和下一个人一样。我主要是出于好奇才做到这一点。 ;)
这是我来到后:
public static class StringExtendsionsMethods
{
public static int IndexOfUsingBoundary(this String s, String word)
{
var firstLetter = word[0].ToString();
StringBuilder sb = new StringBuilder();
bool previousWasLetterOrDigit = false;
int i = 0;
while (i < s.Length - word.Length + 1)
{
bool wordFound = false;
char c = s[i];
if (c.ToString().Equals(firstLetter, StringComparison.CurrentCultureIgnoreCase))
if (!previousWasLetterOrDigit)
if (s.Substring(i, word.Length).Equals(word, StringComparison.CurrentCultureIgnoreCase))
{
wordFound = true;
bool wholeWordFound = true;
if (s.Length > i + word.Length)
{
if (Char.IsLetterOrDigit(s[i + word.Length]))
wholeWordFound = false;
}
if (wholeWordFound)
return i;
sb.Append(word);
i += word.Length;
}
if (!wordFound)
{
previousWasLetterOrDigit = Char.IsLetterOrDigit(c);
sb.Append(c);
i++;
}
}
return -1;
}
}
但我不能居功这个!我在谷歌搜索here, on StackOverflow后发现这个,然后修改它。 ;)
使用此方法代替上述代码中的标准IndexOf
。
我将如何使用它来只匹配第一次出现? – Trevor
哦,看起来很简单...替换(...,1) – Trevor
@Trevor这将工作,**但**没有一个选项,接受int和ignorecase。 –