PHP在UTF8下生成的.csv在excel中乱码问题解决

由于Windows下的Excel默认使用ANSI字符集,打开UTF8格式的CSV文件会导致中文乱码。通过在CSV文件开头添加UTF8-BOM头可以指示Excel以UTF8模式打开,从而避免乱码。代码实现包括在创建CSV文件后插入BOM头,并提供了一个处理BOM头和检测文件字符集的类文件。
摘要由CSDN通过智能技术生成

其实原理很简单,因为office是在windows下的,用的是ansi字符集,所以打开utf8的文件时,中文内容会变成乱码。这时需要告诉excel当前的.csv文件是utf8格式的,他就能正常识别。

解决方式是在创建文件后,在最开头写入一个 UTF8-BOM头标识,excel就知道这个文档用utf8格式打开。

代码如下,请参考输出bom头的这行。

$sCsvFile = storage_path('app/csv_vc_cb_'. time() . rand(100, 999) .'.csv'); //csv文件
$fp = fopen($sCsvFile, 'w'); //打开文件
fputs($fp, pack('CCC',0xef,0xbb,0xbf)); //输出bom头
//写行首
$aRow = ['账本id', '虚拟币名', '用户id', '手机号', '真名', '花名', '身份证' , '本期期初额', '本期期末额', '末额', '可核销额'];
fputcsv($fp, $aRow); //输出行
fclose($fp);

再提供一个类文件,可以直接处理读取bom文件时的头剥离,与识别文件的字符集是否为 utf8,直接用吧。

/**
 * 字符串BOM检测
 * @author JerryLi
 *
 */
class StringBom{
    /**
     * 移除字符串的BOM
     *
     * @param  string $str 输入字符串
     * @r
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值