目次
ディスカッションに返信(解決策)
ホームページ バックエンド開発 PHPチュートリアル php Excelエクスポートの文字化けコードの問題

php Excelエクスポートの文字化けコードの問題

May 26, 2018 am 11:12 AM
excel php 文字化け 輸出


/**     
* 用于生成excel文件的函数     
* author:walker     
* @param $data 生成excel的数据(二维数组形式)     
* @param null $savefile 生成excel的文件名(保不指定,则为当前时间戳)     
* @param null $title 生成excel的表头(一维数组形式)     
* @param string $sheetname 生成excel的sheet名称(缺省为sheet1)     
*/    
function exportExcel($data,$savefile=null,$title=null,$sheetname='sheet1'){        
//若没有指定文件名则为当前时间戳        
if(is_null($savefile)){            
$savefile=time();        
}        
//若指字了excel表头,则把表单追加到正文内容前面去        
if(is_array($title)){            
array_unshift($data,$title);        
}        import('Org.Util.PHPExcel');		
import('Org.Util.PHPExcel.IOFactory');        
import('PHPExcel.Util.PHPExcel.Reader.Excel5');        
$objPHPExcel = new \PHPExcel();        
//Excel内容        
foreach($data as $k => $v){            
$obj=$objPHPExcel->setActiveSheetIndex(0);            
$row=$k+1;//行            
$nn=0;            
foreach($v as $vv){                
$col=chr(65+$nn);//列                
$vv = iconv("UTF-8", "GB2312//IGNORE",$vv);                
$obj->setCellValue($col.$row,$vv);//列,行,值                
$nn++;            
}        
}        
$objPHPExcel->getActiveSheet()->setTitle($sheetname);        
$objPHPExcel->setActiveSheetIndex(0);        
header('Content-Type: application/vnd.ms-excel');        
header('Content-Disposition: attachment;filename="'.$savefile.'.xls"');        
header("Content-Type: application/vnd.ms-excel; charset=UTF-8");        
header('Cache-Control: max-age=0');        
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');        
$objWriter->save('php://output');        
exit;    }     
/**     
*     
* 导出Excel     
*/    
function expUser(){//导出Excel        
$xlstitle  = array('id','商品编码','模板编号','商品名称','总库存','当前库存','供应商');        
$xlssql = M('erp_inventory');        
$xlsData  = $xlssql->getField('id,p_code,mid,pname,banlance,cur_banlance,factory');
//         show_bug($xlsData);die;       
$this->exportExcel($xlsData,time(),$xlstitle);             
}
ログイン後にコピー

上記は thinkphp フレームワークを使用したコードです。 2 番目の写真は、どこで問題が発生し、どのように解決するかです。

ディスカッションに返信(解決策)

29 行をコメントアウト $vv = iconv("UTF-8", "GB2312//IGNORE",$vv);

29 行をコメントアウト $vv = iconv( "UTF- 8", "GB2312//IGNORE",$vv);


最初に29行目はありませんでしたが、後から追加しました。追加しても追加しなくても、エクスポートされた効果は同じです。 !

thinkphp を使用しているので、utf-8 である必要があります
そして、PHPExcel のデフォルトの文字セットも utf-8 です
では、なぜ
$vv = iconv("UTF-8", "GB2312//IGNORE ", $vv);
utf-8 を gb2312 に変換しますか?

投稿行 52、$xlsData によって出力されるコードの一部は 2 次元配列ですが、ここでは問題ありません。お役に立てれば幸いです

$vv = iconv("UTF-8", "GB2312//IGNORE",$vv);
$vv = iconv("UTF-8", "UTF-8//IGNORE") " ,$vv);
$vv = iconv("GB2312", "UTF-8//IGNORE",$vv);
上記の 3 つをすべて試しましたが、結果は同じでした。 !

thinkphp を使用しているため、utf-8 である必要があります
そして、PHPExcel のデフォルトの文字セットも utf-8 です
では、なぜ次のようにする必要があります
$vv = iconv("UTF-8", "GB2312// IGNORE" ,$vv);
utf-8 を gb2312 に変換しますか?

理解できない?私はそれを明らかにしませんでしたか?ヒューリスティックな解決策は受け入れられないようです
トランスコードに iconv を使用するステートメントをすべて削除してください。
これは理解できるはずですよね?
PHPExcel を使用して Excel に書き込まれるデータは、UTF-8 でエンコードされたデータである必要があります
これは理解すべきですよね?

様子を見て gbk に変換してください。iconv を火星文字と繁体字中国語の文字に変換するときに問題が発生します
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

理解できません?私はそれを明らかにしませんでしたか?ヒューリスティックな解決策は受け入れられないようです
トランスコードに iconv を使用するステートメントをすべて削除してください。
これは理解できるはずですよね?
PHPExcel を使用して Excel に書き込まれるデータは、UTF-8 でエンコードされたデータである必要があります
これは理解すべきですよね?

わかりました、29 行目と 38 行目は削除しても役に立ちません。どこを削除すればよいでしょうか?

gbk に変換して見てください。 iconv を火星文字と繁体字に変換するときに問題が発生します。
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

$vv = 、 それはどういう意味ですか?

38 は削除する必要はありません

それでも機能しない場合は、スクリーンショットを投稿してください

gbk に変換して確認してください iconv を火星文字と繁体字中国語の文字に変換する際に問題が発生します
$vv = mb_convert_encoding ($vv =, "GBK"," UTF-8");

$vv =, どういう意味ですか?
タイプミス、$vv

見た目を gbk に変換してください。iconv を火星文字と繁体字中国語の文字に変換するときに問題が発生します
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

$vv = 、どういう意味ですか?
タイプミス、$vv
は通過できません、

38は削除する必要はありません
それでも動作しない場合はスクリーンショットを投稿します

38行追加されましたWPSのせいでしょうか?会社ではWPS、自宅ではoffice2007を使用しているのですが、現在コードが文字化けしています。ブレーク方法

方法 1:
setlocale(LC_ALL, 'zh_CN');
方法 2:
$str = mb_convert_encoding($str, "UTF-8", "GBK"); // ソース コードは次のようになります。 be GBK、convert For utf-8
ブログをご覧ください。 csvファイルをインポートしましたが、原理は同じだと思います。
http://blog.csdn.net/phpfenghuo/article/details/17483261

方法 1:
setlocale(LC_ALL, 'zh_CN')
方法 2:
$str = mb_convert_encoding($str, "UTF-8 ", "GBK"); //既知のソースコードは GBK で、utf-8 に変換されています
ブログが見れます。 csvファイルをインポートしましたが、原理は同じだと思います。

方法 1: LC_ALL とは何ですか?
方法 2: エラーを報告する
これら 2 つの文はどこに配置されていますか? $vv の代わりに 28 行目に置くと機能しません。

不是很清楚 Untitled Spreadsheet、Unknown Creator 是如何来的
为什么是 $obj=$objPHPExcel->setActiveSheetIndex(0);
而不是 $obj = $objPHPExcel->getActiveSheet();

刚才单独测试了一下,你的首发代码应该是没有问题的,当然是没有 iconv 的
问题在于文档中出现的 Untitled Spreadsheet、Unknown Creator 是如何产生的

不是很清楚 Untitled Spreadsheet、Unknown Creator 是如何来的
为什么是 $obj=$objPHPExcel->setActiveSheetIndex(0);
而不是 $obj = $objPHPExcel->getActiveSheet();

按照你说的,变成这样了,Untitled Spreadsheet、Unknown Creator没有了

转为gbk看下,另iconv转火星文和繁体字会有问题
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

$vv =, 什么意思?
笔误,$vv
过不了呢、
extension=php_mbstring.dll把这个扩展开了

转为gbk看下,另iconv转火星文和繁体字会有问题
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

$vv =, 什么意思?
笔误,$vv
过不了呢、
extension=php_mbstring.dll把这个扩展开了
php 的extension=php_mbstring.dll 开启了,重启apache,导出没有报错,但还是乱码

你没注意还是有错误信息吗?
A4的Worksheet...Feuilles de calcul
原来的
$objPHPExcel->getActiveSheet()->setTitle($sheetname);
$objPHPExcel->setActiveSheetIndex(0);
并没有错!

不是很清楚 Untitled Spreadsheet、Unknown Creator 是如何来的
为什么是 $obj=$objPHPExcel->setActiveSheetIndex(0);
而不是 $obj = $objPHPExcel->getActiveSheet();

按照你说的,变成这样了,Untitled Spreadsheet、Unknown Creator没有了
刚看错了,应该是28行,还是乱码。

你没注意还是有错误信息吗?
A4的Worksheet...Feuilles de calcul
原来的
$objPHPExcel->getActiveSheet()->setTitle($sheetname);
$objPHPExcel->setActiveSheetIndex(0);
并没有错!


那代码又回来刚开始了,那个乱码的excel 我可以在excel设置里面改编码吗?

对,有转回去了

我前面说了,我单独测试你的代码段是没有问题的。
所以问题可能出在别的地方:比如传入的数据、从表中读取的数据、甚至是你使用的phpexcel类

include 'Plugin/PHPExcel/Classes/PHPExcel.php';
//        import('Org.Util.PHPExcel.IOFactory');
//        import('PHPExcel.Util.PHPExcel.Reader.Excel5');
$data = array(  array('中','文','c'),  array('a','b','c'),  array('a','b','c'),);
$sheetname = '123';
$savefile = time();        
$objPHPExcel = new PHPExcel();        
//Excel内容        
foreach($data as $k => $v){            
$obj=$objPHPExcel->setActiveSheetIndex(0);            
$row=$k+1;//行            
$nn=0;            
foreach($v as $vv){                
$col=chr(65+$nn);//列$vv = iconv('gbk', 'utf-8', $vv);                
$obj->setCellValue($col.$row,$vv);//列,行,值                
$nn++;            
}        
}        
$objPHPExcel->getActiveSheet()->setTitle($sheetname);        
$objPHPExcel->setActiveSheetIndex(0);        
header('Content-Type: application/vnd.ms-excel');        
header('Content-Disposition: attachment;filename="'.$savefile.'.xls"');        
header("Content-Type: application/vnd.ms-excel; charset=UTF-8");        
header('Cache-Control: max-age=0');        
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');        
$objWriter->save('php://output');
ログイン後にコピー

对,有转回去了

我前面说了,我单独测试你的代码段是没有问题的。
所以问题可能出在别的地方:比如传入的数据、从表中读取的数据、甚至是你使用的phpexcel类

include 'Plugin/PHPExcel/Classes/PHPExcel.php';
//        import('Org.Util.PHPExcel.IOFactory');
//        import('PHPExcel.Util.PHPExcel.Reader.Excel5');
$data = array(  array('中','文','c'),  array('a','b','c'),  array('a','b','c'),);
$sheetname = '123';
$savefile = time();        
$objPHPExcel = new PHPExcel();        
//Excel内容        
foreach($data as $k => $v){            
$obj=$objPHPExcel->setActiveSheetIndex(0);            
$row=$k+1;//行            
$nn=0;            
foreach($v as $vv){                
$col=chr(65+$nn);//列
$vv = iconv('gbk', 'utf-8', $vv);                
$obj->setCellValue($col.$row,$vv);//列,行,值                
$nn++;            
}        
}        
$objPHPExcel->getActiveSheet()->setTitle($sheetname);        
$objPHPExcel->setActiveSheetIndex(0);        
header('Content-Type: application/vnd.ms-excel');        
header('Content-Disposition: attachment;filename="'.$savefile.'.xls"');        
header("Content-Type: application/vnd.ms-excel; charset=UTF-8");        
header('Cache-Control: max-age=0');        
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');        
$objWriter->save('php://output');
ログイン後にコピー

源数据,和获取的都没问题,excel类是官网下的,我项目excel导入还用这个这个包啊,应该没问题的。

转为gbk看下,另iconv转火星文和繁体字会有问题
$vv = mb_convert_encoding($vv =, "GBK","UTF-8");

$vv =, 什么意思?
笔误,$vv
过不了呢、
extension=php_mbstring.dll把这个扩展开了
php 的extension=php_mbstring.dll 开启了,重启apache,导出没有报错,但还是乱码
header("Content-Type: application/vnd.ms-excel; charset=UTF-8"); 注释掉这句看看

对,有转回去了
我前面说了,我单独测试你的代码段是没有问题的。
所以问题可能出在别的地方:比如传入的数据、从表中读取的数据、甚至是你使用的phpexcel类

include 'Plugin/PHPExcel/Classes/PHPExcel.php';
//        import('Org.Util.PHPExcel.IOFactory');
//        import('PHPExcel.Util.PHPExcel.Reader.Excel5');$data = array(  array('中','文','c'),  array('a','b','c'),  array('a','b','c'),);
$sheetname = '123';
$savefile = time();        
$objPHPExcel = new PHPExcel();        
//Excel内容        
foreach($data as $k => $v){            
$obj=$objPHPExcel->setActiveSheetIndex(0);            
$row=$k+1;//行            
$nn=0;            
foreach($v as $vv){                
$col=chr(65+$nn);//列$vv = iconv('gbk', 'utf-8', $vv);                
$obj->setCellValue($col.$row,$vv);//列,行,值                
$nn++;            
}        
}        
$objPHPExcel->getActiveSheet()->setTitle($sheetname);        
$objPHPExcel->setActiveSheetIndex(0);        
header('Content-Type: application/vnd.ms-excel');        
header('Content-Disposition: attachment;filename="'.$savefile.'.xls"');        
header("Content-Type: application/vnd.ms-excel; charset=UTF-8");        
header('Cache-Control: max-age=0');        
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');        
$objWriter->save('php://output');
ログイン後にコピー

我弄了一组测试数据,导出还是乱码啊?你不是测试没有问题吗?

好吧,我导出来了,exportexcel重写了,还是这个方法写的有问题,还是谢谢你们啊。

从图中可看到第5、11行都有错误信息
你可把标题去掉,只保留数据体,进行测试
exportExcel 中把这句也注释掉
$objPHPExcel->getActiveSheet()->setTitle($sheetname);

从图中可看到第5、11行都有错误信息

你可把标题去掉,只保留数据体,进行测试
exportExcel 中把这句也注释掉
$objPHPExcel->getActiveSheet()->setTitle($sheetname);

还是不行哦

function exportexcel($data=array(),$title=array(),$filename='report'){    
header("Content-type:application/octet-stream");    
header("Accept-Ranges:bytes");    
header("Content-type:application/vnd.ms-excel");      
header("Content-Disposition:attachment;filename=".$filename.".xls");    
header("Pragma: no-cache");    header("Expires: 0");    
//导出xls 开始    if (!empty($title)){        
foreach ($title as $k => $v) {            
$title[$k]=iconv("UTF-8", "GB2312",$v);        
}        
$title= implode("\t", $title);        
echo "$title\n";    }    
if (!empty($data)){        
foreach($data as $key=>$val){            
foreach ($val as $ck => $cv) {                
$data[$key][$ck]=iconv("UTF-8", "GB2312", $cv);            
}            
$data[$key]=implode("\t", $data[$key]);                    
}       
echo implode("\n",$data);    
} 
}
ログイン後にコピー

我用上面的方法导出来没问题,问题结果是每组数据都在每行excel表格A格中,没有按列排开。能不能帮我改改

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

今まで知らなかったことを後悔している 7 つの PHP 関数 今まで知らなかったことを後悔している 7 つの PHP 関数 Nov 13, 2024 am 09:42 AM

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

See all articles