站长之家 - 站长资讯 - 易采站长站

当前位置: > 建站教程 > 源码教程 > CMS 教程 >

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

2019-10-12 11:32 | 来源:易采站长站 | 编辑:admin |

点评: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进来。修改完之后,问题解决。

软件名称:
ECshop电商网店系统下载
软件语言:
简体/多国语言
软件授权:
个人免费

  • ecshop 后台登陆自动退出的一种可能情况(目录大小-ECshop教程
  • ECSHOP首页商品显示购买次数的实现方法-ECshop教程
  • ecshop调用指定分类的文章的方法介绍-ECshop教程
  • ecshop商品列表页出现一个空的搜索结果-ECshop教程
  • 帝国CMS自动截取简介出现乱码的解决方法-(EmpireCMS)帝国CMS教程
  • ecshop去掉国家省市区,实现手动填写收货地址-ECshop教程
  • Ecshop商品详情一会显示一会不显示-ECshop教程
  • ECSHOP 2.7 版本去除底部版权的方法-ECshop教程
  • Ecshop 去除版权的设置技巧-ECshop教程
  • ECShop显示某商品销售累计效果的实现代码-ECshop教程
  • 网友评论

    关于我们 - 联系我们 - 广告服务 - 版权声明 - 人才招聘 - 友情链接 - 网站地图 - 帮助 - -

    CopyRight © 2010-2016 源码下载 easck.com , All Rights Reserved

    蒙公网安备 15052402000103号

    蒙ICP备14002389-1号