UTF-8 problèmes lors de la lecture d'un fichier CSV avec fgetcsv

J'essaie de lire un fichier CSV et echo le contenu. Mais le contenu affiche les caractères de mal.

Mäx Müstermänn -> Mäx Müstermänn

Encodage du fichier CSV est en UTF-8 sans BOM (vérifié avec Notepad++).

C'est le contenu du fichier CSV:

"Mäx";"Müstermänn"

Mon script PHP

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<?php
$handle = fopen ("specialchars.csv","r");
echo '<table border="1"><tr><td>First name</td><td>Last name</td></tr><tr>';
while ($data = fgetcsv ($handle, 1000, ";")) {
        $num = count ($data);
        for ($c=0; $c < $num; $c++) {
            //output data
            echo "<td>$data[$c]</td>";
        }
        echo "</tr><tr>";
}
?>
</body>
</html>

J'ai essayé d'utiliser setlocale(LC_ALL, 'de_DE.utf8'); comme l'a suggéré ici sans succès. Le contenu est toujours mal affiché.

Ce que je suis absent?

Edit:

Un echo mb_detect_encoding($data[$c],'UTF-8'); me donne de l'UTF-8 UTF-8.

echo file_get_contents("specialchars.csv"); me donne "Mäx";"Müstermänn".

Et

print_r(str_getcsv(reset(explode("\n", file_get_contents("specialchars.csv"))), ';'))

me donne

Array ( [0] => Mäx [1] => Müstermänn )

Ça veut dire quoi?

  • Ce qui se passe quand vous faites echo file_get_contents("specialchars.csv")? Ce qui se passe lorsque vous ne print_r(str_getcsv(reset(explode("\n", file_get_contents("specialchars.csv"))), ';'))?
  • J'ai mis à jour ma question!
InformationsquelleAutor testing | 2012-01-16