ECShop 批量上传商品乱码问题解决

     客户反映,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 = new Spreadsheet_Excel_Reader();
     $reader->setOutputEncoding('utf-8');
     $reader->read($_FILES['file']['tmp_name']);
     $data = $reader->sheets[0]['cells'];


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

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值