美文网首页PHP很实用的知识点总结PHP开发
PHP创建的csv文件在windows上乱码的问题

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

作者: 自由de单车 | 来源:发表于2016-07-08 13:19 被阅读502次

    前言

    做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);
    ?>
    

    相关文章

      网友评论

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

        本文链接:https://www.haomeiwen.com/subject/udfrjttx.html