多くの文字列をループする場合、おそらく Regex は最良のアイデアではない可能性があります。これは優れたツールですが、最速ではありません。
これも機能するサンプルコードです。
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);
編集:
コメントで指摘されているように、上記のコードにはいくつかの問題があります。
そこで、正規表現を使用せずに機能させる方法を見つけることにしました。誤解しないでほしいのですが、私は次の男と同じくらい正規表現が大好きです。私は主に好奇心からこれを行いました。;)
これが私が出会ったものです:
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;
}
}
しかし、私はこれを手柄にすることはできません!ここで、StackOverflowでいくつかのグーグルを行った後、これを見つけて変更しました。;)
IndexOf
上記のコードの標準の代わりに、このメソッドを使用してください。