Das Problem ist, dass die angegebenen diakrits explizit geparst werden müssen, da die doppelten Punkte nicht allein existieren und daher die doppelten Anführungszeichen für diesen Fall verwendet werden. Um Ihr Problem zu lösen, haben Sie dann keine andere Chance, jeden benötigten Fall zu implementieren.
Hier ist ein Ausgangspunkt einen Anhaltspunkt zu bekommen ...
public SomeFunction()
{
string asciiChars = "Dutch has funny chars: a,e,u";
string diacrits = " ' \" \"";
var combinedChars = asciiChars.Zip(diacrits, (ascii, diacrit) =>
{
return CombineChars(ascii, diacrit);
});
var Result = new String(combinedChars.ToArray());
}
private char CombineChars(char ascii, char diacrit)
{
switch (diacrit)
{
case '"':
return AddDoublePoints(ascii);
case '\'':
return AddAccent(ascii);
default:
return ascii;
}
}
private char AddDoublePoints(char ascii)
{
switch (ascii)
{
case 'a':
return 'ä';
case 'o':
return 'ö';
case 'u':
return 'ü';
default:
return ascii;
}
}
private char AddAccent(char ascii)
{
switch (ascii)
{
case 'a':
return 'á';
case 'o':
return 'ó';
default:
return ascii;
}
}
}
Die IEnumerable.Zip ist bereits implemented in .Net 4, aber es in 3,5 bekommen Sie diesen Code benötigen (taken from Eric Lippert):
public static class IEnumerableExtension
{
public static IEnumerable<TResult> Zip<TFirst, TSecond, TResult>
(this IEnumerable<TFirst> first,
IEnumerable<TSecond> second,
Func<TFirst, TSecond, TResult> resultSelector)
{
if (first == null) throw new ArgumentNullException("first");
if (second == null) throw new ArgumentNullException("second");
if (resultSelector == null) throw new ArgumentNullException("resultSelector");
return ZipIterator(first, second, resultSelector);
}
private static IEnumerable<TResult> ZipIterator<TFirst, TSecond, TResult>
(IEnumerable<TFirst> first,
IEnumerable<TSecond> second,
Func<TFirst, TSecond, TResult> resultSelector)
{
using (IEnumerator<TFirst> e1 = first.GetEnumerator())
using (IEnumerator<TSecond> e2 = second.GetEnumerator())
while (e1.MoveNext() && e2.MoveNext())
yield return resultSelector(e1.Current, e2.Current);
}
}
Sie suchen das Gegenteil von string.Normalize, ich fürchte, es gibt keine eingebaute Methode, um zu bekommen, was Sie wollen ... –
Ich denke, er ist nach Normalisierung, es ist nur, dass seine Diakritika sind nicht die Kombination von Zeichen so es funktioniert nicht. –