解决fgetcsv打开csv文件中文无法显示的问题。




上PHP官网翻了一下,原来加上setlocale即可解决。
原本用PHP4没出现这问题,大概是PHP5才会这样吧...
注释:setlocale() 函数仅针对当前脚本改变地区信息。
提示:可以通过 setlocale(LC_ALL,NULL) 把地区信息设置为系统默认。


// utf-8
setlocale(LC_ALL, 'en_US.UTF-8');
// 简体
setlocale(LC_ALL, 'zh_CN');

//设置回系统默认
setlocale(LC_ALL,NULL);

以下是常用的地区标识
zh_CN GB2312
en_US.UTF-8 UTF-8
zh_TW BIG5
zh_HK BIG5-HKSCS
zh_TW.EUC-TW EUC-TW
zh_TW.UTF-8 UTF-8
zh_HK.UTF-8 UTF-8
zh_CN.GBK GBK


<?php
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/

class excel extends Action{
        
        //显示导入
        public function ShowReade(){
                setlocale(LC_ALL,NULL);
                $result = $this->Reade();
                for($i=0;$i<count($result);$i++){
                        for($j=0;$j<count($result[$i]);$j++){
                                //echo mb_detect_encoding($result[$i][$j]);
                                echo $this->expChangeCode($result[$i][$j]).'  '; //页面编码为utf-8时使用,否则中文会出现乱码
                        }
                        echo '<br><br>';
                }
        }


        /**
         * 解决乱码
         */
        function expChangeCode($str){
                $str = mb_convert_encoding($str,"UTF-8","gbk");
                return $str;
        }

        public function Reade(){
                $handle = fopen("2011.csv","r");
                $out = array();
                $n = 0;
                while ($data = fgetcsv($handle, 10000)){
                        $num = count ($data);
                        for($i=0;$i<$num;$i++){
                                $out[$n][$i] = $data[$i];
                        }
                        $n++;
                }
                return $out;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值