之前在使用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";
}
}