Rumah >pembangunan bahagian belakang >tutorial php >PHPExcel保存时文件命中文出现乱码怎么解决?

PHPExcel保存时文件命中文出现乱码怎么解决?

一个新手
一个新手asal
2017-09-27 09:30:134899semak imbas

PHPExcel保存时文件命中文出现乱码怎么解决?

PHPExcel保存时文件命中文出现乱码怎么解决?

Phpexcel导出Excel文件时有两个主要的过程:

    1、定义文件名

    2、填充Excel数据

这两个过程中可能会出现一些乱码问题,下面我来说一下解决办法:

解决文件名的乱码:

乱码原因:

客户使用的中文版Windows系统平台,而Windows平台的文件名编码为gb2312(gbk),而我们网页编码为了跟进现存潮流 一般都采用utf-8(国际化)编码,这时当我们:header("Content-Disposition: inline; filename=\"" . $filename . ".xls-:special:1:-")时就会出现乱码,假如你的网页编码就是gb2312那就不用考虑编码问题了。

解决办法:

对$filename转码,执行:

$filename = iconv("utf-8", "gb2312", $filename);
header("Content-Disposition:attachment;filename=".$filename.".xlsx");

假如你的环境不支持iconv函数可以换别的函数,只要能将$filename的编码转为gbk就行。

但是这样问题又会来了,linux用户又会出现文件名乱码(因为linux平台文件名不是gbk编码)。

考虑到这个问题我采用两个办法:第一:放弃一部分客户,毕竟windows系统用户占绝大部分。第二:像gmail一样,提供两个下载地址。一个文件名gbk编码,一个文件名utf-8编码。

解决Excel内数据乱码:

乱码原因:网页编码与Excel编码不一致。

解决办法:1.既然编码不一致,那让其一致了就OK了。

定义Excel的字符集:

header("Content-Type: text/html; charset=utf-8");

更多相关知识,请访问 PHP中文网!!

Atas ialah kandungan terperinci PHPExcel保存时文件命中文出现乱码怎么解决?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:Laravel中日期时间处理包CarbonArtikel seterusnya:新手入门学习php