网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

解决utf8编码中php导出CSV乱码的方法

小编给大家分享一下解决utf8编码中php导出CSV乱码的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

网站建设哪家好,找创新互联公司!专注于网页设计、网站建设、微信开发、小程序设计、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了顺昌免费建站欢迎大家使用!

解决乱码的方法:1、使用iconv函数将utf8编码转码为GBK,语法“$str = iconv('utf-8', 'GBK//IGNORE', $str));”;2、在输出内容前先输出BOM头,这样Excel就可自动识别到是UTF-8了。

解决utf8编码中php导出CSV乱码的方法

其实需求是把数据导出到Excel,很当然的想到大名鼎鼎的PHPExcel这个库。这个库是很强大,就是比较占用内存,超过10万的数据,在web请求中基本是很难完成了。因此,使用原生PHP导出轻量的csv还是有需求的。

一般情况下,导出UTF-8编码的常规内容到csv当中,用Excel打开都是乱码,更别说一些非主流字符,或者是emoji表情。乱码,是因为在windows系统下,默认的Excel是使用GBK编码解析的。现如今,编码哪还有不是使用UTF-8的,真有,那也是大公司知名产品会为了省那点流量出有GBK等其他编码的版本,一般情况下都是使用UTF-8的。

要解决乱码问题,PHP中做法一般是使用iconv函数进行转码为GBK,这样,默认的Excel打开就不会有问题了。但对于emoji表情等主流字符,GBK并不能显示,转码失败直接为空了。可以添加//IGNORE标记进行忽略,这样只是忽略了它们,其他正常字符是能够保留的。

$str = iconv('utf-8', 'GBK//IGNORE', $str));

这可以说是一种折中方案。能不能不转码直接输出UTF-8?难道Excel还不能自动识别UTF-8进而使用UTF-8来解码显示么?其实是可以的,只是它需要一个BOM头(在非windows的世界里是没有这个东西的),有这个BOM头它就能识别到是UTF-8,否则识别不了用默认的GBK来处理,自然就是乱码了。如何正确输出所谓的BOM头,看代码:

$fp = fopen('./test_csv.csv', 'a');
fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF));//输出BOM头
fputcsv($fp, ['标题']);
fputcsv($fp, ['解决乱码']);
fclose($fp);

可以解决所谓乱码以及正常显示emoji表情等非主流字符。

看完了这篇文章,相信你对解决utf8编码中php导出CSV乱码的方法有了一定的了解,想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


文章题目:解决utf8编码中php导出CSV乱码的方法
文章路径:http://bjjierui.cn/article/pphsod.html

其他资讯