php读取csv数据保存到数组的方法
来源: 阅读:655 次 日期:2015-03-31 11:13:29
温馨提示: 小编为您整理了“php读取csv数据保存到数组的方法”,方便广大网友查阅!

这篇文章主要介绍了php读取csv数据保存到数组的方法,通过封装的类文件实现这一功能,是对csv文件操作的实用技巧,需要的朋友可以参考下

本文实例讲述了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程序设计有所帮助。

更多信息请查看IT技术专栏

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map