php用excel打开乱码,PHP生成CSV文件用Excel打开乱码问题_PHP教程

今天有一同学问我为什么PHP生成CSV文件用Excel打开会出现乱码呢,下面小编来给大家找了一些常见的办法,希望此方法对各位朋友会有所帮助。

百度查证后得知

PHP生成UTF-8编码的CSV文件用Excel打开中文显示乱码,是由于输出的CSV文件中没有BOM。

我们只要简单处理一下即可

那么如何在PHP中输出BOM呢?

在所有内容输出之前

代码如下

复制代码

print(chr(0xEF).chr(0xBB).chr(0xBF));

例.php生成csv时我们可以这样

代码如下

复制代码

print(chr(0xEF).chr(0xBB).chr(0xBF));//设置utf-8 + bom ,处理汉字显示的乱码

echo array2csv($items_data);

function array2csv(array &$array)

{

if (count($array) == 0) {

return null;

}

ob_start();

$df = fopen("php://output", 'w');

fputcsv($df, array_keys(reset($array)));

foreach ($array as $row) {

fputcsv($df, $row);

}

fclose($df);

return ob_get_clean();

}

?>

还有一种办法就是使用Office

打开Microsoft Office 2010 Excel,数据-自文本,如图:

195G92429-0.jpg

导入此csv格式文件,同样要求选择编码,如图:

195G93964-1.jpg

这里选择UTF-8,打开后,发现乱码消除,如图:

195G915H-2.jpg

补:UTF-8是在互联网上使用最广的一种unicode编码的实现方式。UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度

http://www.bkjia.com/PHPjc/633200.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/633200.htmlTechArticle今天有一同学问我为什么PHP生成CSV文件用Excel打开会出现乱码呢,下面小编来给大家找了一些常见的办法,希望此方法对各位朋友会有所帮助...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值