服务器之家

服务器之家 > 正文

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

时间:2019-10-08 11:48     来源/作者: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=newSpreadsheet_Excel_Reader(); 
$reader->setOutputEncoding('utf-8'); 
$reader->read($_FILES['file']['tmp_name']); 
$data=$reader->sheets[0]['cells']; 


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

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
抖音撒撒累累是什么歌 撒撒累累张艺兴歌曲名字
抖音撒撒累累是什么歌 撒撒累累张艺兴歌曲名字 2019-06-05
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
返回顶部