Quand on exporte du texte dans excel ou word (fichiers .csv renommés en .xls, fichiers .txt renommés en .doc ...), les caractères spéciaux sont remplacés par d'autres caractères et rendent le texte illisible.
Le charset n'est malheureusement pas modifiable :(
Cette fonction permet donc de rétablir la plupart des caractères spéciaux connus.
Source / Exemple :
$replace = array(
"Å " => "?", "Å¡" => "?", "Å'" => "?", "Å"" => "?",
"Ÿ" => "?", "ÿ" => "ÿ", "Ã?" => "À", "à " => "à",
"Ã" => "Á", "á" => "á", "Ã?" => "Â", "â" => "â",
"Ã?" => "Ã", "ã" => "ã", "Ã?" => "Ä", "ä" => "ä",
"Ã?" => "Å", "Ã¥" => "å", "Ã?" => "Æ", "æ" => "æ",
"Ã?" => "Ç", "ç" => "ç", "Ã?" => "È", "è" => "è",
"Ã?" => "É", "é" => "é", "Ã?" => "Ê", "ê" => "ê",
"Ã?" => "Ë", "ë" => "ë", "Ã?" => "Ì", "ì" => "ì",
"Ã" => "Í", "Ã" => "í", "Ã?" => "Î", "î" => "î",
"Ã" => "Ï", "ï" => "ï", "Ã" => "Ð", "ð" => "ð",
"Ã'" => "Ñ", "ñ" => "ñ", "Ã'" => "Ò", "ò" => "ò",
"Ã"" => "Ó", "ó" => "ó", "Ã"" => "Ô", "ô" => "ô",
"Ã?" => "Õ", "õ" => "õ", "Ã?" => "Ö", "Ã?" => "Ø",
"ø" => "ø", "Ã?" => "Ù", "ù" => "ù", "Ã?" => "Ú",
"ú" => "ú", "Ã?" => "Û", "û" => "û", "Ã?" => "Ü",
"ü" => "ü", "Ã" => "Ý", "ý" => "ý", "Ã?" => "Þ",
"þ" => "þ", "Ã?" => "ß", "ö" => "ö"
);
function changeAccented($text) {
global $replace;
foreach($replace as $key => $val)
$text = str_replace($key, $val, $text);
return $text;
}
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.