欢迎来到一聚街网
帮助中心

一聚街网

热门搜索:

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

  • 时间:2016-06-29 17:55 编辑:免费源码下载 来源:源码下载 阅读:391
  • 扫一扫,手机访问
摘要: 客户反映,ECShop后台用CSV批量上传商品数据包出现一堆乱码,字段完全对不上。分析了代码后发现,ECShop读CSV的方式弱爆了。在admin/目录下找到good_batch.php这段代码 复制代码代码如下: /*将文件按行读入数组,逐行进行解析*/ $line_number=0; $arr=array(); $goods_list=array(); $field_list=array_k
客户反映,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进来。修改完之后,问题解决。
  • 全部评论(0)
资讯详情页最新发布上方横幅
最新发布的资讯信息
【建站/优化|】常见的网站流量数据统计工具(2018-02-04 19:45)
【建站/优化|】百度优化之用户浏览方式指标(2018-02-04 18:04)
【建站/优化|】百度优化之用户行为指标(2018-02-04 18:02)
【建站/优化|】百度优化之网站流量指标(2018-02-04 17:59)
【建站/优化|】做百度优化排名怎么分析网站指标(2018-02-04 17:57)
【建站/优化|】网络营销投入快速见效(2018-02-04 17:52)
【建站/优化|】时代 ― 微信通过搜索来连接实体世界(2018-02-01 11:23)
【建站/优化|】微信搜索是不是与网站一样有竞价排名(2018-01-31 12:10)
【建站/优化|】如何快速抢占微信搜索入口(2018-01-31 11:01)
【建站/优化|】微信搜索:移动互联网第一流量入口(2018-01-31 10:51)
联系我们
联系客服
网站客服 联系客服
手机版

扫一扫进手机版
返回顶部