Intereting Posts
Php-код для загрузки pdf-файла с сервера не работает почему PHPUnit пытается найти файл с именем testuite? PHP: позволяет вашей собственной функции работать с циклом while HTML в символах формы Symfony2 вместо обычного текста Как определить, является ли выбранное изображение для загрузки допустимым? имеют разные статические URL в динамической странице isset () vs strlen () – вычисление быстрой / четкой длины строки Укоротить определения маршрута Zend Framework Как получить данные из базы данных mysql с помощью javascript? Регулярное выражение для получения основного домена URL-адреса Fat Free Framework (F3): пользовательская страница 404 (и другие ошибки) Как скрыть ссылки в строке состояния браузера при наведении указателя мыши на ссылки на веб-странице? 301 перенаправление на новый домен и новую папку имен Использование Webservice для отправки имени пользователя и пароля с PHP на JAVA Api Запуск скрипта Python в PHP: захват всех выходов

Проблемы UTF-8 при чтении CSV-файла с помощью fgetcsv

Я пытаюсь читать CSV и эхо-контент. Но содержимое отображает символы неправильно.

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

Кодирование CSV-файла – UTF-8 без спецификации (отмечено в Notepad ++).

Это содержимое файла CSV:

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

Мой скрипт 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> 

Я попытался использовать setlocale(LC_ALL, 'de_DE.utf8'); как предлагается здесь без успеха. Содержимое по-прежнему отображается неправильно.

Что мне не хватает?

Редактировать:

echo mb_detect_encoding($data[$c],'UTF-8'); дает мне UTF-8 UTF-8.

echo file_get_contents("specialchars.csv"); дает мне "Mäx";"Müstermänn" .

А также

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

дает мне

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

Что это значит?

Попробуй это:

 <?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, ";")) { $data = array_map("utf8_encode", $data); //added $num = count ($data); for ($c=0; $c < $num; $c++) { // output data echo "<td>$data[$c]</td>"; } echo "</tr><tr>"; } ?> 

Обнаруженная аналогичная проблема: анализ CSV-файла со специальными символами, такими как é, è, ö и т. Д.

Следующее работало отлично для меня:

Чтобы правильно представлять символы на странице html, заголовок был необходим:

 header('Content-Type: text/html; charset=UTF-8'); 

Для правильного анализа каждого символа я использовал:

 utf8_encode(fgets($file)); 

Не забудьте использовать во всех последующих строковых операциях «Многобайтовые строковые функции», например:

 mb_strtolower($value, 'UTF-8'); 

Попытайтесь поместить это в верхнюю часть своего файла (перед любым другим выходом):

 <?php header('Content-Type: text/html; charset=UTF-8'); ?> 

Теперь я получил его работу (после удаления команды header ). Я думаю, проблема заключалась в том, что кодировка php-файла была в ISO-8859-1. Я установил его в UTF-8 без спецификации. Я думал, что уже сделал это, но, возможно, я сделал еще одну отмену.

Кроме того, я использовал SET NAMES 'utf8' для базы данных. Теперь это также верно в базе данных.

Проблема в том, что функция возвращает UTF-8 (она может проверяться с использованием mb_detect_encoding), но не конвертировать , и эти символы принимаются как UTF-8. Поэтому необходимо сделать обратное преобразование в исходное кодирование (Windows-1251 или CP1251) с помощью iconv . Но поскольку fgetcsv возвращает массив, я предлагаю написать пользовательскую функцию: [ Извините за мой английский ]

 function customfgetcsv(&$handle, $length, $separator = ';'){ if (($buffer = fgets($handle, $length)) !== false) { return explode($separator, iconv("CP1251", "UTF-8", $buffer)); } return false; } 

В моем случае исходный файл имеет кодировку windows-1250, а iconv печатает тонны уведомлений о незаконных символах в строке ввода …

Поэтому это решение мне очень помогло:

 /** * getting CSV array with UTF-8 encoding * * @param resource &$handle * @param integer $length * @param string $separator * * @return array|false */ private function fgetcsvUTF8(&$handle, $length, $separator = ';') { if (($buffer = fgets($handle, $length)) !== false) { $buffer = $this->autoUTF($buffer); return str_getcsv($buffer, $separator); } return false; } /** * automatic convertion windows-1250 and iso-8859-2 info utf-8 string * * @param string $s * * @return string */ private function autoUTF($s) { // detect UTF-8 if (preg_match('#[\x80-\x{1FF}\x{2000}-\x{3FFF}]#u', $s)) return $s; // detect WINDOWS-1250 if (preg_match('#[\x7F-\x9F\xBC]#', $s)) return iconv('WINDOWS-1250', 'UTF-8', $s); // assume ISO-8859-2 return iconv('ISO-8859-2', 'UTF-8', $s); } 

Ответ на ответ @ manvel – используйте str_getcsv вместо взрыва – из-за таких случаев:

 some;nice;value;"and;here;comes;combinated;value";and;some;others 

Взрыв взорвет строку на части:

 some nice value "and here comes combinated value" and some others 

но str_getcsv взорвет строку на части:

 some nice value and;here;comes;combinated;value and some others