本文实例讲述了php读取csv数据保存到数组的方法。分享给大家供大家参考。具体分析如下:
csv是常用的excel格式的替代品,很多时候我们导出数据是都会导成csv格式的,这样和excel没什么区别,下面的程序是要读取csv数据保存到数组我们要对数据进行操作,所以保存到数据,代码如下:
复制代码 代码如下:$info=csvtoarray::open('teste.csv'); 
//echo '<pre>'; 
//print_r($info); 
//echo '</pre>'; 
foreach ($info as $c) 
 { 
  echo '学号:'.$c[0]; 
  echo '姓名:'.$c[1]; 
  echo '年龄:'.$c[2]; 
  echo '身高:'.$c[3].'<br>'; 
 } 
 
 
 final class csvtoarray{ 
 
  /** 
   * 把csv文件解析为一个数组返回 
   * 
   * @param string $file 要解析的csv文件路径  
   * @param char $delimiter csv文件里的内容分隔符 默认为; 
   * @return array 
   */ 
  public static function open($file, $delimiter = ';'){ 
   return self::ordenamultiarray(self::csvarray($file, $delimiter), 1); 
  } 
 
  private function csvarray($file, $delimiter) 
  { 
   $result = array(); 
   $size = filesize($file) + 1; 
   $file = fopen($file, 'r'); 
   $keys = fgetcsv($file, $size, $delimiter); 
   fseek($file,0);//这里原来的没有..自己加上..这样能读取到第一行的内容 
   while ($row = fgetcsv($file, $size, $delimiter)) 
   { 
    for($i = 0; $i < count($row); $i++) 
    { 
     if(array_key_exists($i, $keys)) 
     { 
      $row[$keys[$i]] = $row[$i]; 
     } 
    } 
    print_r($row); 
    $result[] = $row; 
   } 
 
   fclose($file); 
 
   return $result; 
  } 
  private function ordenamultiarray($multiarray, $secondindex) 
  {
   while (list($firstindex, ) = each($multiarray)) 
   $indexmap[$firstindex] = $multiarray[$firstindex][$secondindex]; 
   asort($indexmap); 
   while (list($firstindex, ) = each($indexmap)) 
   if (is_numeric($firstindex)) 
   $sortedarray[] = $multiarray[$firstindex]; 
   else $sortedarray[$firstindex] = $multiarray[$firstindex]; 
   return $sortedarray; 
  } 
}
希望本文所述对大家的php程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?