ホームページ >バックエンド開発 >PHPチュートリアル >UTF-8でエンコードされたCSVファイルをExcelで開くとPHPで文字化けが発生する問題を解決しました。

UTF-8でエンコードされたCSVファイルをExcelで開くとPHPで文字化けが発生する問題を解決しました。

WBOY
WBOYオリジナル
2016-06-13 13:13:51983ブラウズ

UTF-8でエンコードされたCSVファイルをExcelで開くとPHPで文字化けが発生する問題を解決

が を書きました
実は、この問題はずっと前に発生していて、その時は openoffice は正常に開いていましたが、その後 Excel が異常に開いたので、解決するしかありませんでした。エンコード。

今回もこの問題に遭遇しました。ネットで調べたところ、出力された CSV ファイルに BOM がなかったことが原因でした。 BOM とは何ですか?

UCSエンコードには「ZERO WIDTH NO-BREAK SPACE」という文字があり、そのエンコードはFEFFです。 FFFE は UCS には存在しない文字ですので、実際の送信では出現しないはずです。 UCS 仕様では、バイト ストリームを送信する前に文字「ZERO WIDTH NO-BREAK SPACE」を送信することを推奨しています。このように、受信機が FEFF を受信した場合は、バイト ストリームがビッグ エンディアンであることを示し、FFFE を受信した場合は、バイト ストリームがリトル エンディアンであることを示します。したがって、「ZERO WIDTH NO-BREAK SPACE」という文字は BOM とも呼ばれます。
UTF-8 では、バイト順序を示すために BOM は必要ありませんが、BOM を使用してエンコード方式を示すことができます。文字「ZERO WIDTH NO-BREAK SPACE」の UTF-8 エンコーディングは EF BB BF です。したがって、受信側が EF BB BF で始まるバイト ストリームを受信すると、それが UTF-8 でエンコードされていることを認識します。
Windows は、BOM を使用してテキスト ファイルのエンコーディングをマークします。

では、PHP で BOM を出力するにはどうすればよいでしょうか?

すべてのコンテンツが出力される前

print(chr(0xEF).chr(0xBB).chr(0xBF));
?
?
<?php

function writeCsvToFile($file,array $data){
	$fp = fopen($file, 'w');
	
	//Windows下使用BOM来标记文本文件的编码方式
	fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF));
	
	foreach ($data as $line) {
		fputcsv($fp, $line);
	}
	
	fclose($fp);
}

$file = "./testcsv.csv";
$data = array(
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
	array(1,'色色',12345,'vb200'),
);

writeCsvToFile($file,$data);
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。