0

0

php csv to array(csv 转数组)方法与代码

php中文网

php中文网

发布时间:2016-07-25 08:59:39

|

1713人浏览过

|

来源于php中文网

原创

  1. //ini_set('memory_limit', '-1'); // 如果csv比较大的话,可以添加。
  2. /*
  3. * $file : csv file
  4. * $csvDataArr : header of csv table, eg: arary('name','sex','age') or array(0,1,2)
  5. * $specialhtml : whether do you want to convert special characters to html entities ?
  6. * $removechar : which type do you want to remove special characters in array keys, manual or automatical ?
  7. * edit http://bbs.it-home.org
  8. */
  9. class csv_to_array
  10. {
  11. private $counter;
  12. private $handler;
  13. private $length;
  14. private $file;
  15. private $seprator;
  16. private $specialhtml;
  17. private $removechar = 'manual';
  18. private $csvDataArr;
  19. private $csvData = array();
  20. function __construct($file = '', $csvDataArr = '', $specialhtml = true, $length = 1000, $seprator = ',')
  21. {
  22. $this->counter = 0;
  23. $this->length = $length;
  24. $this->file = $file;
  25. $this->seprator = $seprator;
  26. $this->specialhtml = $specialhtml;
  27. $this->csvDataArr = is_array($csvDataArr) ? $csvDataArr : array();
  28. $this->handler = fopen($this->file, "r");
  29. }
  30. function get_array()
  31. {
  32. $getCsvArr = array();
  33. $csvDataArr = array();
  34. while(($data = fgetcsv($this->handler, $this->length, $this->seprator)) != FALSE)
  35. {
  36. $num = count($data);
  37. $getCsvArr[$this->counter] = $data;
  38. $this->counter++;
  39. }
  40. if(count($getCsvArr) > 0)
  41. {
  42. $csvDataArr = array_shift($getCsvArr);
  43. if($this->csvDataArr) $csvDataArr = $this->csvDataArr;
  44. $counter = 0;
  45. foreach($getCsvArr as $csvValue)
  46. {
  47. $totalRec = count($csvValue);
  48. for($i = 0; $i
  49. {
  50. $key = $this->csvDataArr ? $csvDataArr[$i] : $this->remove_char($csvDataArr[$i]);
  51. if($csvValue[$i]) $this->csvData[$counter][$key] = $this->put_special_char($csvValue[$i]);
  52. }
  53. $counter++;
  54. }
  55. }
  56. return $this->csvData;
  57. }
  58. function put_special_char($value)
  59. {
  60. return $this->specialhtml ? str_replace(array('&','" ','\'',''),array('&','"',''',''),$value) : $value;
  61. }
  62. function remove_char($value)
  63. {
  64. $result = $this->removechar == 'manual' ? $this->remove_char_manual($value) : $this->remove_char_auto($value);
  65. return str_replace(' ','_',trim($result));
  66. }
  67. private function remove_char_manual($value)
  68. {
  69. return str_replace(array('&','"','\'','','(',')','%'),'',trim($value));
  70. }
  71. private function remove_char_auto($str,$x=0)
  72. {
  73. $x==0 ? $str=$this->make_semiangle($str) : '' ;
  74. eregi('[[:punct:]]',$str,$arr);
  75. $str = str_replace($arr[0],'',$str);
  76. return eregi('[[:punct:]]',$str) ? $this->remove_char_auto($str,1) : $str;
  77. }
  78. private function make_semiangle($str)
  79. {
  80. $arr = array('0' => '0', '1' => '1', '2' => '2', '3' => '3', '4' => '4',
  81. '5' => '5', '6' => '6', '7' => '7', '8' => '8', '9' => '9',
  82. 'A' => 'A', 'B' => 'B', 'C' => 'C', 'D' => 'D', 'E' => 'E',
  83. 'F' => 'F', 'G' => 'G', 'H' => 'H', 'I' => 'I', 'J' => 'J',
  84. 'K' => 'K', 'L' => 'L', 'M' => 'M', 'N' => 'N', 'O' => 'O',
  85. 'P' => 'P', 'Q' => 'Q', 'R' => 'R', 'S' => 'S', 'T' => 'T',
  86. 'U' => 'U', 'V' => 'V', 'W' => 'W', 'X' => 'X', 'Y' => 'Y',
  87. 'Z' => 'Z', 'a' => 'a', 'b' => 'b', 'c' => 'c', 'd' => 'd',
  88. 'e' => 'e', 'f' => 'f', 'g' => 'g', 'h' => 'h', 'i' => 'i',
  89. 'j' => 'j', 'k' => 'k', 'l' => 'l', 'm' => 'm', 'n' => 'n',
  90. 'o' => 'o', 'p' => 'p', 'q' => 'q', 'r' => 'r', 's' => 's',
  91. 't' => 't', 'u' => 'u', 'v' => 'v', 'w' => 'w', 'x' => 'x',
  92. 'y' => 'y', 'z' => 'z',
  93. '(' => '(', ')' => ')', '〔' => '[', '〕' => ']', '【' => '[',
  94. '】' => ']', '〖' => '[', '〗' => ']', '“' => '[', '”' => ']',
  95. '‘' => '[', '’' => ']', '{' => '{', '}' => '}', '《' => '
  96. '》' => '>',
  97. '%' => '%', '+' => '+', '—' => '-', '-' => '-', '~' => '-',
  98. ':' => ':', '。' => '.', '、' => ',', ',' => '.', '、' => '.',
  99. ';' => ',', '?' => '?', '!' => '!', '…' => '-', '‖' => '|',
  100. '”' => '"', '’' => '`', '‘' => '`', '|' => '|', '〃' => '"',
  101. ' ' => ' ','$'=>'$','@'=>'@','#'=>'#','^'=>'^','&'=>'&','*'=>'*');
  102. return strtr($str, $arr);
  103. }
  104. function __destruct(){
  105. fclose($this->handler);
  106. }
  107. }
  108. // example:
  109. $csv = new csv_to_array('user.csv');
  110. echo "
    "; print_r($csv->get_array()); echo "
    ";
  111. ?>
复制代码

2、使用一般函数

  1. function csv_to_array($csv)
  2. {
  3. $len = strlen($csv);
  4. $table = array();
  5. $cur_row = array();
  6. $cur_val = "";
  7. $state = "first item";
  8. for ($i = 0; $i
  9. {
  10. //sleep(1000);
  11. $ch = substr($csv,$i,1);
  12. if ($state == "first item")
  13. {
  14. if ($ch == '"') $state = "we're quoted hea";
  15. elseif ($ch == ",") //empty
  16. {
  17. $cur_row[] = ""; //done with first one
  18. $cur_val = "";
  19. $state = "first item";
  20. }
  21. elseif ($ch == "\n")
  22. {
  23. $cur_row[] = $cur_val;
  24. $table[] = $cur_row;
  25. $cur_row = array();
  26. $cur_val = "";
  27. $state = "first item";
  28. }
  29. elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!";
  30. else
  31. {
  32. $cur_val .= $ch;
  33. $state = "gather not quote";
  34. }
  35. }
  36. elseif ($state == "we're quoted hea")
  37. {
  38. if ($ch == '"') $state = "potential end quote found";
  39. else $cur_val .= $ch;
  40. }
  41. elseif ($state == "potential end quote found")
  42. {
  43. if ($ch == '"')
  44. {
  45. $cur_val .= '"';
  46. $state = "we're quoted hea";
  47. }
  48. elseif ($ch == ',')
  49. {
  50. $cur_row[] = $cur_val;
  51. $cur_val = "";
  52. $state = "first item";
  53. }
  54. elseif ($ch == "\n")
  55. {
  56. $cur_row[] = $cur_val;
  57. $table[] = $cur_row;
  58. $cur_row = array();
  59. $cur_val = "";
  60. $state = "first item";
  61. }
  62. elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!";
  63. else
  64. {
  65. $cur_val .= $ch;
  66. $state = "we're quoted hea";
  67. }
  68. }
  69. elseif ($state == "wait for a line feed, if so close out row!")
  70. {
  71. if ($ch == "\n")
  72. {
  73. $cur_row[] = $cur_val;
  74. $cur_val = "";
  75. $table[] = $cur_row;
  76. $cur_row = array();
  77. $state = "first item";
  78. }
  79. else
  80. {
  81. $cur_row[] = $cur_val;
  82. $table[] = $cur_row;
  83. $cur_row = array();
  84. $cur_val = $ch;
  85. $state = "gather not quote";
  86. }
  87. }
  88. elseif ($state == "gather not quote")
  89. {
  90. if ($ch == ",")
  91. {
  92. $cur_row[] = $cur_val;
  93. $cur_val = "";
  94. $state = "first item";
  95. }
  96. elseif ($ch == "\n")
  97. {
  98. $cur_row[] = $cur_val;
  99. $table[] = $cur_row;
  100. $cur_row = array();
  101. $cur_val = "";
  102. $state = "first item";
  103. }
  104. elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!";
  105. else $cur_val .= $ch;
  106. }
  107. }
  108. return $table;
  109. }
  110. //pass a csv string, get a php array
  111. // example:
  112. $arr = csv_to_array(file_get_contents('user.csv'));
  113. echo "
    "; print_r($arr);   echo "
    "
  114. ?>
复制代码

或者

  1. $arrCSV = array();
  2. // Open the CSV
  3. if (($handle = fopen("user.csv", "r")) !==FALSE) {
  4. // Set the parent array key to 0
  5. $key = 0;
  6. // While there is data available loop through unlimited times (0) using separator (,)
  7. while (($data = fgetcsv($handle, 0, ",")) !==FALSE) {
  8. // Count the total keys in each row
  9. $c = count($data);
  10. //Populate the array
  11. for ($x=0;$x
  12. $key++;
  13. } // end while
  14. // Close the CSV file
  15. fclose($handle);
  16. } // end if
  17. echo "
    "; print_r($arrCSV); echo "
    ";
  18. ?>
复制代码

至于哪种更好用,看自己的实际需求与个人爱好了,实际工作中csv转array的需求还是不少,建议大家多练习,多掌握。

Molica AI
Molica AI

一款聚合了多种AI工具的一站式创作平台

下载


相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

616

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

194

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

91

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

20

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

54

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

598

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

56

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号