2014-07-22 1 views
0

У меня возникла проблема с заменой символов, отличных от ASCII, на их эквивалент ASCII.Заменить специальные символы эквивалентом ASCII в C# Silverlight

я могу сделать это просто в Windows Forms, используя что-то вроде этого:

Encoding.UTF8.GetString(Encoding.GetEncoding("Cyrillic").GetBytes("Crazy text with żźćńąśłęó and other special characters")); 

и я буду получать что-то вроде этого:

Сумасшедшего текста с zzcnasleo и другими специальными символами

Проблема в том, что в Silverlight у меня нет кодировок типа «Кириллица» - я могу использовать только четыре из них:

utf-8 - UTF8Encoding 
utf-16 - UnicodeEncoding (little-endian) 
utf-16BE - UnicodeEncoding (big-endian) 
utf-16LE - UnicodeEncoding (little-endian) 

Вы знаете, как добиться этого же результата в C# Silverlight?

+0

Взгляните на эти вопросы: [ ASCIIEncoding В Windows Phone 7] (http://stackoverflow.com/questions/4022281/asciiencoding-in-windows-phone-7) и [Encoding.ASCII недоступен в Silverlight есть альтернатива?] (Http: // stackoverflow .com/вопросы/10010840/кодирование-ASCII-не-доступно-в-Silverlight-там-A-альтернатива). – Abbas

+0

Пример в этом вопросе, заменяющий специальные символы вопросительным знаком - это не то, что я ищу :-( – Marek

+0

И другие ответы на этот вопрос? В противном случае создайте свой собственный конвертер? – Abbas

ответ

0

я написал свой собственный конвертер, но не так круто:

private string Convert(string value) 
{ 
    string[] nonAsciiCharacters = new string[] { "À", "Á", "Â", "Ã", "Å", "Ä", "Ç", "È", "É", "Ê", "Ë", "Ì", "Í", "Î", "Ï", "Ñ", "Ò", "Ó", "Ô", "Ö", "Õ", "Ù", "Ú", "Û", "Ü", "Ý", "à", "á", "â", "ã", "ä", "å", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", "ñ", "ò", "ó", "ô", "õ", "ö", "ø", "ù", "ú", "û", "ý", "ÿ", "Ā", "ā", "Ă", "ă", "Ą", "ą", "Ć", "ć", "Ĉ", "ĉ", "Ċ", "ċ", "Č", "č", "Ď", "ď", "Đ", "đ", "Ē", "ē", "Ĕ", "ĕ", "Ė", "ė", "Ę", "ę", "Ě", "ě", "Ĝ", "ĝ", "Ğ", "ğ", "Ġ", "ġ", "Ģ", "ģ", "Ĥ", "ĥ", "Ĩ", "ĩ", "Ī", "ī", "Ĭ", "ĭ", "Į", "į", "İ", "ı", "Ĵ", "ĵ", "Ķ", "ķ", "ĸ", "Ĺ", "ĺ", "Ļ", "ļ", "Ľ", "ľ", "Ŀ", "ŀ", "Ł", "ł", "Ń", "ń", "Ņ", "ņ", "Ň", "ň", "ʼn", "Ŋ", "ŋ", "Ō", "ō", "Ŏ", "ŏ", "Ő", "ő", "Ŕ", "ŕ", "Ŗ", "ŗ", "Ř", "ř", "Ś", "ś", "Ŝ", "ŝ", "Ş", "ş", "Š", "š", "Ţ", "ţ", "Ť", "ť", "Ũ", "ũ", "Ū", "ū", "Ŭ", "ŭ", "Ů", "ů", "Ű", "ű", "Ų", "ų", "Ŵ", "ŵ", "Ŷ", "ŷ", "Ÿ", "Ź", "ź", "Ż", "ż", "Ž", "ž", "Ơ", "ơ", "Ư", "ư", "Ǎ", "ǎ", "Ǐ", "ǐ", "Ǒ", "ǒ", "Ǔ", "ǔ", "Ǖ", "ǖ", "Ǘ", "ǘ", "Ǚ", "ǚ", "Ǜ", "ǜ", "Ǻ", "ǻ", "Ǿ", "ǿ" }; 
    string[] asciiCharacters = new string[] { "A", "A", "A", "A", "A", "A", "C", "E", "E", "E", "E", "I", "I", "I", "I", "N", "O", "O", "O", "O", "O", "U", "U", "U", "U", "Y", "a", "a", "a", "a", "a", "a", "c", "e", "e", "e", "e", "i", "i", "i", "i", "n", "o", "o", "o", "o", "o", "o", "u", "u", "u", "y", "y", "A", "a", "A", "a", "A", "a", "C", "c", "C", "c", "C", "c", "C", "c", "D", "c", "D", "d", "E", "e", "E", "e", "E", "e", "E", "e", "E", "e", "G", "g", "G", "g", "G", "g", "G", "g", "H", "h", "I", "i", "I", "i", "I", "i", "I", "i", "I", "i", "J", "j", "K", "k", "k", "L", "l", "L", "l", "L", "l", "L", "l", "L", "l", "N", "n", "N", "n", "N", "n", "n", "N", "n", "O", "o", "O", "o", "O", "o", "R", "r", "R", "r", "R", "r", "S", "s", "S", "s", "S", "s", "S", "s", "T", "t", "T", "t", "U", "u", "U", "u", "U", "u", "U", "u", "U", "u", "U", "u", "W", "w", "Y", "y", "Y", "Z", "z", "Z", "z", "Z", "z", "O", "o", "U", "u", "A", "a", "I", "i", "O", "o", "U", "u", "U", "u", "U", "u", "U", "u", "U", "u", "A", "a", "O", "o" }; 

    value = Regex.Replace(name.Trim(), @"[\s]", "_"); // Replace white with under character 

    for (int currentChar = 0; currentChar < nonAsciiCharacters.Length; currentChar ++) 
    { 
     value = value.Replace(nonAsciiCharacters[i], asciiCharacters[currentChar ]); 
    } 

    return Regex.Replace(value, @"[^0-9a-zA-Z_]+", string.Empty); // Remove white characters 
} 

Может быть кто-то сделает это лучше и поставить на этот пост :-)