• 技术文章 >后端开发 >PHP问题

    如何解决php fgetcsv乱码问题

    藏色散人藏色散人2020-07-27 10:06:08原创887

    php fgetcsv乱码是因为导入的csv文件是以ansi编码保存的,其解决办法就是将中文操作系统环境对应的编设置为“gbk”,也就是通过手动更改浏览器字符编码为“gbk”即可。

    推荐:《PHP教程

    php使用fgetcsv读取csv文件出现乱码的解决方法

    一般来说在php中碰到乱码多半是编码问题,在这里我们实例分析了fgetcsv读取csv文件乱码原因所在与解决方法。

    例子如下:

    代码如下:

    function get_csv_contents( $file_target ){
     $handle  = fopen( $file_target, 'r');
     while ($data = fgetcsv($handle, 1000, ",")) {
     
      $num = count($data);
      echo "<p> $num fields in line $row: <br>n";
      $row++;
      for ($c=0; $c < $num; $c++) {
       echo $data[$c]. "<br>n";;
       /*echo getUTFString($data[$c])*/
      }
     }
     fclose($handle);
    }

    导入的csv文件是以ansi编码保存的,对于中文操作系统环境对应的应该就是gbk编码了,通过手动更改浏览器字符编码为gbk,乱码的情况消失了,于时进行了下面调整。

    代码如下:

    $data = eval('return '.iconv('gbk','utf-8',var_export($data,true)).';');

    $data为需要转换编码的数组。

    补充:LINUX FGETCSV读取GBK数据乱码

    当Linux系统是使用的默认设置,则在该Linux服务器上对gbk的csv格式文件进行处理的时候,就会出现乱码现象。

    解决方法是:

    使用 setlocale 函数设置环境变量。比如要设置使用gb 的区域设置可以在fgetcsv前使用下面的语句。

    代码如下:

    setlocale(LC_ALL,array('zh_CN.gbk','zh_CN.gb2312','zh_CN.gb18030'));

    具体使用哪些locale 可以使用linux 命令 locale -a 查看系统支持哪些

    以上就是如何解决php fgetcsv乱码问题的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:fgetcsv php
    上一篇:Linux下如何安装PHP扩展模块? 下一篇:php上传大文件失败怎么办
    线上培训班

    相关文章推荐

    • 用 PHP 自带函数 fputcsv 和 fgetcsv 来导出报表和导入报表• 有关php fgetcsv()函数的文章推荐10篇• php中fgetcsv()函数用法实例详解• php fgetcsv() 函数语法参数enclosure详解

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网