生成csv文件时总是不能生成gbk编码的文件问题

在使用Yaf项目生成CSV文件时遇到编码问题,文件默认为UTF-8导致Excel2007打开乱码。尽管服务器环境与本地一致,且尝试升级Yaf版本未解决问题,最终发现是源代码中一个文件含有UTF-8 BOM头导致无法生成GBK编码的CSV。删除BOM头后,服务器上成功生成GBK编码文件,问题得到解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      之前在使用yaf进行一个项目时遇到一个问题,在生成csv文件时只能生成utf-8编码的文件,可是如果csv文件是utf-8编码的话,使用excel2007打开文件乱码,只有文件是gbk编码的时候excel2007打开的时候才会是正常的,其他版本的话,utf-8+BOM或者gbk编码都可以正常打开。

       当时是本地环境下生成的文件可以是gbk,只需要把写入csv文件的字符串编码转成gbk编码就可以,但是将代码上传到服务器的时候就无法生成gbk编码文件,后来看了测试环境上的服务器编码设置什么的和本地一样,只是yaf版本不一样了,但是考虑到也不应该是yaf版本的问题造成的,还是把本地yaf 升级到和测试版本一致了,本地还是正常的,测试服务器不行。实在找不出问题,最后将测试的代码全部覆盖,然后试了之后发现生成的文件正常了,csv文件是gbk编码的了,然后就开始找涉及到的文件哪里不同,最后发现其中一个文件的编码是uft-8+BOM,而本地的文件是utf-8而没有BOM头的,问题就这样解决了。大哭大哭


header("Content-Type: application/octet-stream");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="*****.csv"');
foreach ($result as $key => $value) {
    foreach ($value as $k => $v) {
        echo iconv('utf-8', 'gbk', $v) . "\n";
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值