继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

PHP创建的csv文件在windows上乱码的问题

aluckdog
关注TA
已关注
手记 443
粉丝 68
获赞 393

前言

做PHP开发的时候,由于业务需要,可能要经常导出csv文件。使用PHP将数据导出到csv文件不难,使用fputcsv函数就可以了,但导出来的csv文件在windows系统上使用office excel打开时,中文部分会乱码(使用金山的WPS打开不会),这是由于windows系统默认使用GBK编码导致的,所以,在以UTF-8为默认编码的系统上,比如Mac OS上就不会乱码。

解决方法

那么怎么解决这个乱码问题呢?方法很简单,只要在创建csv文件的时候,先往文件头部写入一个BOM头就可以了,有了BOM头,软件就知道这个文件是使用UTF-8编码的,打开的时候就会使用UTF-8编码来解析,而不是使用系统默认的GBK。

代码

<?php$fp = fopen('test.csv', 'w');if (!is_resource($fp)) {    exit('Create CSV file failed');
}
fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF)); // 写入BOM头,防止乱码fputcsv($fp, array('用户名称', '性别'));
fclose($fp);?>



作者:自由de单车
链接:https://www.jianshu.com/p/22ef589ff820

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP