首页建站经验 ecshop商品批量上传乱码读CSV的方式问题

ecshop商品批量上传乱码读CSV的方式问题

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

 客户反映,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进来。修改完之后,问题解决。

 

本文来自网络,不代表1号站长-站长学院|资讯交流平台立场。转载请注明出处: https://www.1cn.cc/jianzhan/jingyan/15550.html
上一篇UEditor教程:关于jsp版ueditor1.2.5上传图片失败问题的解决方法
下一篇 dedecms文章内页获取缩略图的调用标签
admin

作者: admin

这里可以再内容模板定义一些文字和说明,也可以调用对应作者的简介!或者做一些网站的描述之类的文字或者HTML!

为您推荐

评论列表()

    联系我们

    联系我们

    0898-88888888

    在线咨询: QQ交谈

    邮箱: email@wangzhan.com

    工作时间:周一至周五,9:00-17:30,节假日休息

    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部