您好,欢迎来到菜鸟吧源码网-本站资源仅供学习与参考,禁止用于商业或违法行为!
  • 首 页
  • 下载APP
  • 公告:菜鸟吧APP于2024.9.15正式上线,请首页右上角进入下载,本站资源均来源于互联网及会员投稿发布,所有资源仅供学习参考研究使用,请勿商用或其它非法用途,商用请购买正版,否则产生一切后果由用户自行承担!谢谢!

     

    当前位置:主页 > 站长学堂 > ecshop >
    ecshop商品批量上传乱码CSV的问题,怎么解决
    时间:2019-10-15 14:50 作者:菜鸟哥 浏览:收藏 挑错 打印

    ECShop后台用CSV批量上传商品数据包出现一堆乱码,问题相当严重经分析之后发现ECShop读CSV的方式弱爆了,接下来为大家详细介绍下解决方案,感兴趣的各位可以参考下哈

    客户反映,ECShop后台用CSV批量上传商品数据包出现一堆乱码,字段完全对不上。分析了代码后发现,ECShop读CSV的方式弱爆了。在admin/目录下找到good_batch.php这段代码

    代码如下:

    /*将文件按行读入数组,逐行进行解析*/
    $line_number=0;
    $arr=array();
    $goods_list=array();
    $field_list=array_keys($_LANG['upload_goods']);//字段列表
    $data=file($_FILES['file']['tmp_name']);

    用file方法将每行作为一个记录读入数组$data中。这里会有个问题,当商品描述里出现换行符,读入就会出错。
    继续往下看。ECShop根据上传时选择的编码类型,如果不是UTF-8则会强制转换成UTF-8。但也只是支持中文GB2312编码,客户上传的数据包却是Unicode编码(客户用淘宝助理导出),结果就乱码了。
    代码如下:

    //转换编码
    if(($_POST['charset']!='UTF8')&&(strpos(strtolower(EC_CHARSET),'utf')===0))
    {
    $line=ecs_iconv($_POST['charset'],'UTF8',$line);
    }

    EC的编码转换果真是奇葩,好端端的mb库放着不用,偏要自己搞一套。用phpExcelReader导入Excel文件就工作得很好,编码都不存在问题。于是,把这段代码改了。

    代码如下:

    /*将文件按行读入数组,逐行进行解析*/
    $line_number=0;
    $arr=array();
    $goods_list=array();
    $field_list=array_keys($_LANG['upload_goods']);//字段列表
    $reader=newSpreadsheet_Excel_Reader();
    $reader->setOutputEncoding('utf-8');
    $reader->read($_FILES['file']['tmp_name']);
    $data=$reader->sheets[0]['cells'];

    phpExcelReader包含两个文件,使用时需要将Excel/reader.phpinclude进来。修改完之后,问题解决

    郑重声明:
    本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
    我们不承担任何技术及版权问题,且不对任何资源负法律责任。
    如无法下载,联系站长索要。
    如有侵犯您的版权,请给我们来信:cainiaovip8@qq.com,我们尽快处理。

    修改ECSHOP评论表单中的Email为非必填的教程修改ECSHOP评论表单中的Email为非必填
    介绍ecshop中如何添加限时抢购功能介绍ecshop中如何添加限时抢购功能
    ecshop数据库ecs_stats短时间内会变很大的解决方案ecshop数据库ecs_stats短时间内会变很