以前、PHPチュートリアルブログの友人から、php Excel Reader2.21を使ってエクセルをエクスポートした際に中国語が文字化けする問題を解決する方法を教えていただきました。 php Excel Reader を使用して Excel ヘルプをエクスポートすることが役立つことを願っています。
php Excelリーダー入門
php Excel Reader は Excel の内容を読み取る php Excel クラスです チュートリアルで紹介した PHP Excel Reader でエクスポートされた中国語文字化けの解決策は PHP Excel Reader 2.21 をベースにしているため、エクスポートされた中国語コードの文字化けの解決策も同様ですPHP Excel Reader のバージョンは PHP のバージョンによって異なりますので、必ず正しいバージョンの PHP Excel Reader をダウンロードしてください。
php Excel Reader2.21でエクスポートした中国語の文字化けを解決するにはどうすればよいですか?
php Excel Reader2.21 をダウンロードしたら、PHP 環境設定の実行ディレクトリに解凍し、example.php を開いて、最初に
を確認してください。
|
$data
= Spreadsheet_Excel_Reader( 1 Spreadsheet_Excel_Reader($file='',$store_extended_info=true,$outputEncoding='') ; |
|
Spreadsheet_Excel_Reader( $file " 1 $data
=
new Spreadsheet_Excel_Reader("example.xls",true,"GB2312"); =true, = 1 var
$_defaultEncoding
=
"UTF-8"; |
1 |
$data = 新しい Spreadsheet_Excel_Reader("example.xls") ; |
1 |
$data = 新しい Spreadsheet_Excel_Reader("example.xls", true、"GB2312") ; |
1 |
var $_defaultEncoding = "UTF-8"; |
が
に変更されました
|
var $_defaultEncoding = "GB2312"; |
php Excel ReaderでエクスポートしたExcelが文字化けする問題を解決できます。
では、上記のチュートリアルで変更した後も example.xls に中国語を追加した後も、example.php が依然として文字化けを出力するのはなぜでしょうか?これは、php Excel リーダー クラスの dump 関数を呼び出して、エクスポートされた Excel ファイルの内容を HTML 形式で出力するために使用されるためです。この問題は、この関数の htmlentities 関数が原因です。文字は HTML エンティティに変換されます。プロトタイプは次のとおりです
1 |
htmlentities(string,quotestyle,character-set) |
1 |
htmlentities(string,引用スタイル,文字-セット)スパン> |
1 |
$val = htmlentities($val); |
1
|
$val = htmlentities($val); |
が に変更されました
1
|
$val = htmlentities($val,ENT_COMPAT,"GB2312"); |
解決策 2
1 |
$val = htmlspecialchars($val); |
1 |
$val = htmlentities($val); |
が に変更されました
1 |
$val = htmlspecialchars($val); |
Excel のエクスポートにダンプ関数を使用しない場合は、_defaultEncoding 変数を変更するか、
new Spreadsheet_Excel_Reader(excel file name, true, "GB2312"); を渡すことで、エクスポートされた文字化けの問題を解決できます。 HTML を使用して Excel をエクスポートするには、ダンプ関数を使用する場合、エクスポートされた Excel が文字化けする問題を解決するには、htmlentities 関数を変更する必要があります。
ここまで、php Excel Reader2.21を使用してExcelをエクスポートする際に中国語が文字化けする問題の解決方法をご紹介しました。 注意: PHP Web サイト開発チュートリアル-leapsoul.cn 転載の際は、元のソースとこの記述をリンクの形で明記してください。