38

CSVを読み取って、コンテンツをエコーし​​ようとしています。しかし、コンテンツは文字を間違って表示します。

MäxMüstermänn->MäxMüstermänn

CSVファイルのエンコードはBOMなしの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-8UTF-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 )

どういう意味ですか?

4

6 に答える 6

68

これを試して:

<?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>";
}
?>
于 2014-10-23T13:34:24.823 に答える
18

同様の問題が発生しました:é、è、öなどの特殊文字を含むCSVファイルの解析...

以下は私にとってうまくいきました:

HTMLページで文字を正しく表すには、ヘッダーが必要でした。

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

すべての文字を正しく解析するために、私は以下を使用しました:

utf8_encode(fgets($file));

次のすべての文字列操作で、次のような「マルチバイト文字列関数」を使用することを忘れないでください。

mb_strtolower($value, 'UTF-8');
于 2014-01-27T13:52:12.600 に答える
8

これを(他の出力の前に)ファイルの先頭に配置してみてください。

<?php

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

?>
于 2012-01-16T19:11:11.107 に答える
7

私の場合、ソースファイルには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の回答への応答-explodeの代わりにstr_getcsvを使用してください-このような場合のために:

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

explodeは、文字列をパーツに分解します。

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

ただし、str_getcsvは文字列をパーツに分解します。

some
nice
value
and;here;comes;combinated;value
and
some
others
于 2017-07-14T07:50:05.093 に答える
5

問題は、関数がUTF-8(mb_detect_encodingを使用してチェックできます)を返すが、変換せず、これらの文字がUTF-8と見なされることです。したがって、 iconvを使用して初期エンコーディング(Windows-1251またはCP1251)に逆変換する必要があります。しかし、fgetcsvによって配列が返されるため、カスタム関数を作成することをお勧めします。[英語で申し訳ありません]

function customfgetcsv(&$handle, $length, $separator = ';'){
    if (($buffer = fgets($handle, $length)) !== false) {
        return explode($separator, iconv("CP1251", "UTF-8", $buffer));
    }
    return false;
}
于 2013-10-06T19:56:39.827 に答える
2

headerこれで動作しました(コマンドを削除した後)。問題は、phpファイルのエンコーディングがISO-8859-1であったことだと思います。BOMなしでUTF-8に設定しました。私はすでにそれをやったと思っていましたが、おそらく私は追加の取り消しを行いました。

さらに、SET NAMES 'utf8'データベースに使用しました。これで、データベースでも正しくなりました。

于 2012-01-17T16:47:13.780 に答える