I have e.g.
string str ='Àpple';
string strNew="";
char[] A = {'À','Á','Â','Ä'};
char[] a = {'à','á','â','ä'};
I want to look through the str and see if found replace with Ascii code ‘A’ . So the result should be:
strNew = 'Apple';
Here is my code:
for (int i = 0; i < str.Length; i++)
{
if(str[i].CompareTo(A))
strNew += 'A'
else if(str[i].CompareTo(a))
strNew +='a'
else
strNew += str[i];
}
But the compare function doesn’t work, so what other function I can use?
It sounds like you could just use:
but there are certainly more efficient ways of doing this. In particular, avoid string concatenation in a loop.
My guess is that there are Unicode normalization approaches which don’t require you to hard-code all this data, too. I’m sure I remember one somewhere, around encoding fallbacks, but I can’t put my finger on it… EDIT: I suspect it’s around
String.Normalize– worth a look, at least.At the very least, this would be more efficient: