网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的考试资料:

 

标题 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进来。修改完之后,问题解决。
随便看

 

在线学习网考试资料包含高考、自考、专升本考试、人事考试、公务员考试、大学生村官考试、特岗教师招聘考试、事业单位招聘考试、企业人才招聘、银行招聘、教师招聘、农村信用社招聘、各类资格证书考试等各类考试资料。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/17 20:28:28