duanji1026 2016-10-11 13:25
浏览 146
已采纳

PHP读取CSV并忽略某些列

I have a simple PHP script that reads a CSV file and generates an array from this:

<?php
$file = fopen('food.csv', 'r');
$allfile = [];
$idsColumnsWanted = array(0,1,16);
while (($line = fgetcsv($file)) !== FALSE) {

  $i = 0;

  foreach ($line as $i => $cell) {
      if (!in_array($i, $idsColumnsWanted)) {
          continue;
      }
      $allfile[] = $line;
      $i++;
  }

}
fclose($file);
?>

I'd like to display just the data in columns 0, 1 & 16.

I have made an attempt above, but it still outputs the entire CSV.

  • 写回答

1条回答 默认 最新

  • dongzhidian3538 2016-10-11 13:37
    关注

    You can do it with array_intersect_key:

    $file = fopen('food.csv', 'r');
    $allfile = [];
    
    $idsColumnsWanted = array_flip([0, 1, 16]);
    
    while (false !== $fields = fgetcsv($file)) {
        $allfile[] = array_intersect_key($fields, $idsColumnsWanted);
    }
    
    fclose($file);
    

    Note: if you don't want to preserve the column numbers as keys in your result array, use array_values(array_intersect_key(...)).

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器