找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 206|回复: 0

[cms教程] ecshop商品批量上传乱码读CSV的方式问题

[复制链接]

该用户从未签到

发表于 2019-3-24 16:27:00 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
   
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文件就工作得很好,编码都不存在问题。于是,把这段代码改了。 复...

   
内容已隐藏,请关注公众号输入验证码查看

               
验证码 

  

本帖支持关注公众号查看

【无套路  无套路  无套路 扫描二维码关注公众号发送【验证码】收到验证码 在上面输入点击提交查看即可显示隐藏内容】

回复

使用道具 举报

网站地图|页面地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2025-5-25 23:40

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表