php 读取淘宝卖家下载的CSV订单文件数据

本文介绍2018年淘宝更新其订单导出格式后,如何使用PHP读取新的CSV文件格式。文章提供了一种通过逐行解析并转换字符集的方法来解决读取不完整的问题。

2018年7月份,淘宝突然改了后台导出的订单文件格式,改变点如下:

1、字段有变化,增加支付信息,所以列信息有变化

2、原来分隔符是\t,制表符,现在是逗号,换行符是\n ,unix的换行符(LF)

 

 

折腾了几次,发现php 用读取csv的函数读取,读取的数据不全,有些行读取不到。

最后,还是用读取整个文件来处理。函数如下

function read_csv($cvs){
  setlocale(LC_ALL, 'zh_CN');
  $rsl=array();
  $tmpfile=file_get_contents($cvs);
  $rows=explode("\n",$tmpfile);
  foreach ($rows as $rk => $row) {
    $tmp=explode(",",$row);
    foreach ($tmp as $ik => $item) {
      $tmp_item=iconv('GB2312','UTF-8',$item);
      $tmp_item=str_replace(array('"','='),array(''),$tmp_item);
      $rsl[$rk][$ik]=$tmp_item;
    }
  }
  return $rsl;
}

 

转载于:https://www.cnblogs.com/huangju6/p/9328440.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值