加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP生成CSV文件在Excel中乱码是咋回事?

发布时间:2023-06-03 13:40:30 所属栏目:PHP教程 来源:
导读:跟大家讲解下有关“PHP生成CSV文件在Excel中乱码是怎么回事?”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。

PHP生成UTF-8编码的CSV文件用Ex
跟大家讲解下有关“PHP生成CSV文件在Excel中乱码是怎么回事?”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。
 
PHP生成UTF-8编码的CSV文件用Excel打开乱码?
 
原因:是由于输出的CSV文件中没有BOM。
 
什么是BOM?
 
在UCS 编码中有一个叫做”ZERO WIDTH NO-BREAK SPACE”的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输字符”ZERO WIDTH NO-BREAK SPACE”。这样如果接收者收到FEFF,就表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little- Endian的。因此字符”ZERO WIDTH NO-BREAK SPACE”又被称作BOM。
 
UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8编码是EF BB BF。所以如果接收者收到以EF BB BF开头的字节流,就知道这是UTF-8编码了。
 
Windows就是使用BOM来标记文本文件的编码方式的。
 
如何在PHP中输出BOM?
 
在所有内容输出之前
 
print(chr(0xEF).chr(0xBB).chr(0xBF));
 
示例代码:
 
<?php
 
    function writeCsvToFile($file,array $data){
 
        $fp = fopen($file, 'w');
 
        //Windows下使用BOM来标记文本文件的编码方式
 
        fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF));
 
        foreach ($data as $line) {
 
            fputcsv($fp, $line);
 
        }
 
        fclose($fp);
 
    }
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!