一次性讀取csv文件內所有行的數據
<?php $file = fopen('windows_2011_s.csv','r'); while ($data = fgetcsv($file)) { //每次讀取CSV里面的一行內容 //print_r($data); //此為一個數組,要獲得每一個數據,訪問數組下標即可 $goods_list[] = $data; } //print_r($goods_list); /* foreach ($goods_list as $arr){ if ($arr[0]!=""){ echo $arr[0]."<br>"; } } */ echo $goods_list[2][0]; fclose($file); ?>
讀取csv文件的某一行數據
<?php function get_file_line( $file_name, $line ){ $n = 0; $handle = fopen($file_name,'r'); if ($handle) { while (!feof($handle)) { ++$n; $out = fgets($handle, 4096); if($line==$n) break; } fclose($handle); } if( $line==$n) return $out; return false; } echo get_file_line("windows_2011_s.csv", 10); ?>
讀取csv文件制定行數(行區間)
<?php function get_file_line( $file_name, $line_star, $line_end){ $n = 0; $handle = fopen($file_name,"r"); if ($handle) { while (!feof($handle)) { ++$n; $out = fgets($handle, 4096); if($line_star <= $n){ $ling[] = $out; } if ($line_end == $n) break; } fclose($handle); } if( $line_end==$n) return $ling; return false; } $aa = get_file_line("windows_2011_s.csv", 11, 20); //從第11行到第20行 foreach ($aa as $bb){ echo $bb."<br>"; } ?>
另外從網上找的兩種方法(沒測試,不知道好不好使)
<? $handle=fopen("1.csv","r"); while(!feof($handle)){ $buffer=fgetss($handle,2048); $data=explode(",",$buffer); $num=count($data); for($i=0;$i<$num;$i++){ print_r($data); } } ?>
<? $handle=fopen("1.csv","r"); $row=1; while($data=fgetcsv($handle,1000,",")){ $num=count($data); for($i=0;$i<$num;$i++){ echo $data[$i]; } $row++; } ?>