- 浏览: 13746875 次
- 性别:
- 来自: 洛杉矶
文章分类
- 全部博客 (1994)
- Php / Pear / Mysql / Node.js (378)
- Javascript /Jquery / Bootstrap / Web (435)
- Phone / IOS / Objective-C / Swift (137)
- Ubuntu / Mac / Github / Aptana / Nginx / Shell / Linux (335)
- Perl / Koha / Ruby / Markdown (8)
- Java / Jsp (12)
- Python 2 / Wxpython (25)
- Codeigniter / CakePHP (32)
- Div / Css / XML / HTML5 (179)
- WP / Joomla! / Magento / Shopify / Drupal / Moodle / Zimbra (275)
- Apache / VPN / Software (31)
- AS3.0/2.0 / Flex / Flash (45)
- Smarty (6)
- SEO (24)
- Google / Facebook / Pinterest / SNS (80)
- Tools (22)
最新评论
-
1455975567:
xuezhongyu01 写道wocan23 写道我想问下那个 ...
Mysql: LBS实现查找附近的人 (两经纬度之间的距离) -
xuezhongyu01:
wocan23 写道我想问下那个111.1是怎么得来的我也看不 ...
Mysql: LBS实现查找附近的人 (两经纬度之间的距离) -
18335864773:
试试 pageoffice 在线打开 PDF 文件吧. pag ...
jquery在线预览PDF文件,打开PDF文件 -
青春依旧:
opacity: 0.5; 个人喜欢这种方式!关于其他css特 ...
css透明度的设置 (兼容所有浏览器) -
July01:
推荐用StratoIO打印控件,浏览器和系统的兼容性都很好,而 ...
搞定网页打印自动分页问题
1. 使用类
注意: user.csv 第一行默认为数组的键, 且第一行不会被打印; (区别于下面的普通函数方法 )
例如:
name | age | gender |
zhang | 23 | male |
li | 20 | female |
结果:
Array ( [0] => Array ( [name] => zhang [age] => 23 [gender] => male ) [1] => Array ( [name] => li [age] => 20 [gender] => female ) )
回到正题:
<?php //ini_set('memory_limit', '-1'); // 如果csv比较大的话,可以添加。 /* * $file : csv file * $csvDataArr : header of csv table, eg: arary('name','sex','age') or array(0,1,2) * $specialhtml : whether do you want to convert special characters to html entities ? * $removechar : which type do you want to remove special characters in array keys, manual or automatical ? */ class csv_to_array { private $counter; private $handler; private $length; private $file; private $seprator; private $specialhtml; private $removechar = 'manual'; private $csvDataArr; private $csvData = array(); function __construct($file = '', $csvDataArr = '', $specialhtml = true, $length = 1000, $seprator = ',') { $this->counter = 0; $this->length = $length; $this->file = $file; $this->seprator = $seprator; $this->specialhtml = $specialhtml; $this->csvDataArr = is_array($csvDataArr) ? $csvDataArr : array(); $this->handler = fopen($this->file, "r"); } function get_array() { $getCsvArr = array(); $csvDataArr = array(); while(($data = fgetcsv($this->handler, $this->length, $this->seprator)) != FALSE) { $num = count($data); $getCsvArr[$this->counter] = $data; $this->counter++; } if(count($getCsvArr) > 0) { $csvDataArr = array_shift($getCsvArr); if($this->csvDataArr) $csvDataArr = $this->csvDataArr; $counter = 0; foreach($getCsvArr as $csvValue) { $totalRec = count($csvValue); for($i = 0; $i < $totalRec ; $i++) { $key = $this->csvDataArr ? $csvDataArr[$i] : $this->remove_char($csvDataArr[$i]); if($csvValue[$i]) $this->csvData[$counter][$key] = $this->put_special_char($csvValue[$i]); } $counter++; } } return $this->csvData; } function put_special_char($value) { return $this->specialhtml ? str_replace(array('&','" ','\'','<','>'),array('&','"',''','<','>'),$value) : $value; } function remove_char($value) { $result = $this->removechar == 'manual' ? $this->remove_char_manual($value) : $this->remove_char_auto($value); return str_replace(' ','_',trim($result)); } private function remove_char_manual($value) { return str_replace(array('&','"','\'','<','>','(',')','%'),'',trim($value)); } private function remove_char_auto($str,$x=0) { $x==0 ? $str=$this->make_semiangle($str) : '' ; eregi('[[:punct:]]',$str,$arr); $str = str_replace($arr[0],'',$str); return eregi('[[:punct:]]',$str) ? $this->remove_char_auto($str,1) : $str; } private function make_semiangle($str) { $arr = array('0' => '0', '1' => '1', '2' => '2', '3' => '3', '4' => '4', '5' => '5', '6' => '6', '7' => '7', '8' => '8', '9' => '9', 'A' => 'A', 'B' => 'B', 'C' => 'C', 'D' => 'D', 'E' => 'E', 'F' => 'F', 'G' => 'G', 'H' => 'H', 'I' => 'I', 'J' => 'J', 'K' => 'K', 'L' => 'L', 'M' => 'M', 'N' => 'N', 'O' => 'O', 'P' => 'P', 'Q' => 'Q', 'R' => 'R', 'S' => 'S', 'T' => 'T', 'U' => 'U', 'V' => 'V', 'W' => 'W', 'X' => 'X', 'Y' => 'Y', 'Z' => 'Z', 'a' => 'a', 'b' => 'b', 'c' => 'c', 'd' => 'd', 'e' => 'e', 'f' => 'f', 'g' => 'g', 'h' => 'h', 'i' => 'i', 'j' => 'j', 'k' => 'k', 'l' => 'l', 'm' => 'm', 'n' => 'n', 'o' => 'o', 'p' => 'p', 'q' => 'q', 'r' => 'r', 's' => 's', 't' => 't', 'u' => 'u', 'v' => 'v', 'w' => 'w', 'x' => 'x', 'y' => 'y', 'z' => 'z', '(' => '(', ')' => ')', '〔' => '[', '〕' => ']', '【' => '[', '】' => ']', '〖' => '[', '〗' => ']', '“' => '[', '”' => ']', '‘' => '[', '’' => ']', '{' => '{', '}' => '}', '《' => '<', '》' => '>', '%' => '%', '+' => '+', '—' => '-', '-' => '-', '~' => '-', ':' => ':', '。' => '.', '、' => ',', ',' => '.', '、' => '.', ';' => ',', '?' => '?', '!' => '!', '…' => '-', '‖' => '|', '”' => '"', '’' => '`', '‘' => '`', '|' => '|', '〃' => '"', ' ' => ' ','$'=>'$','@'=>'@','#'=>'#','^'=>'^','&'=>'&','*'=>'*'); return strtr($str, $arr); } function __destruct(){ fclose($this->handler); } } // example: $csv = new csv_to_array('user.csv'); echo "<pre>"; print_r($csv->get_array()); echo "</pre>";
2. 使用一般函数
<? function csv_to_array($csv) { $len = strlen($csv); $table = array(); $cur_row = array(); $cur_val = ""; $state = "first item"; for ($i = 0; $i < $len; $i++) { //sleep(1000); $ch = substr($csv,$i,1); if ($state == "first item") { if ($ch == '"') $state = "we're quoted hea"; elseif ($ch == ",") //empty { $cur_row[] = ""; //done with first one $cur_val = ""; $state = "first item"; } elseif ($ch == "\n") { $cur_row[] = $cur_val; $table[] = $cur_row; $cur_row = array(); $cur_val = ""; $state = "first item"; } elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!"; else { $cur_val .= $ch; $state = "gather not quote"; } } elseif ($state == "we're quoted hea") { if ($ch == '"') $state = "potential end quote found"; else $cur_val .= $ch; } elseif ($state == "potential end quote found") { if ($ch == '"') { $cur_val .= '"'; $state = "we're quoted hea"; } elseif ($ch == ',') { $cur_row[] = $cur_val; $cur_val = ""; $state = "first item"; } elseif ($ch == "\n") { $cur_row[] = $cur_val; $table[] = $cur_row; $cur_row = array(); $cur_val = ""; $state = "first item"; } elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!"; else { $cur_val .= $ch; $state = "we're quoted hea"; } } elseif ($state == "wait for a line feed, if so close out row!") { if ($ch == "\n") { $cur_row[] = $cur_val; $cur_val = ""; $table[] = $cur_row; $cur_row = array(); $state = "first item"; } else { $cur_row[] = $cur_val; $table[] = $cur_row; $cur_row = array(); $cur_val = $ch; $state = "gather not quote"; } } elseif ($state == "gather not quote") { if ($ch == ",") { $cur_row[] = $cur_val; $cur_val = ""; $state = "first item"; } elseif ($ch == "\n") { $cur_row[] = $cur_val; $table[] = $cur_row; $cur_row = array(); $cur_val = ""; $state = "first item"; } elseif ($ch == "\r") $state = "wait for a line feed, if so close out row!"; else $cur_val .= $ch; } } return $table; } //pass a csv string, get a php array // example: $arr = csv_to_array(file_get_contents('user.csv')); echo "<pre>"; print_r($arr); echo "</pre>"
或者
<? $arrCSV = array(); // Open the CSV if (($handle = fopen("user.csv", "r")) !==FALSE) { // Set the parent array key to 0 $key = 0; // While there is data available loop through unlimited times (0) using separator (,) while (($data = fgetcsv($handle, 0, ",")) !==FALSE) { // Count the total keys in each row $c = count($data); //Populate the array for ($x=0;$x<$c;$x++) $arrCSV[$key][$x] = $data[$x]; $key++; } // end while // Close the CSV file fclose($handle); } // end if echo "<pre>"; print_r($arrCSV); echo "</pre>"; ?>
发表评论
-
PHP: 在类(class)中加载动态函数, 变量函数或半变量函数 variable function/method
2016-09-03 07:54 7185最终实例在下方 以前 ... -
MySQL入门 (七) : 储存引擎与资料型态
2016-09-03 07:49 45651 表格与储存引擎 表格(table)是资料库中用来储存 ... -
MySQL入门 (六) : 字元集与资料库
2016-09-03 07:47 45771 Character Set与Collation 任何 ... -
MySQL入门 (五) : CRUD 与资料维护
2016-09-03 07:46 54881 取得表格资讯 1.1 DESCRIBE指令 「 ... -
MySQL入门 (四) : JOIN 与UNION 查询
2016-09-03 07:42 45121 使用多个表格 在「world」资料库的「countr ... -
PHP: 关键字global 和 超全局变量$GLOBALS的用法、解释、区别
2016-08-31 12:07 5046$GLOBALS 是一个关联数组,每一个变量为一个 ... -
MySQL入门 (三) : 运算式与函式
2016-08-31 12:01 4392运算式(expressions)已经 ... -
MySQL入门 (二) : SELECT 基础查询
2016-08-31 11:56 46901 查询资料前的基本概念 1.1 表格、纪录 ... -
MySQL入门 (一) : 资料库概论与MySQL的安装
2016-08-31 11:51 44691. 储存与管理资料 储存与管理资料一直是资讯应用上最基本 ... -
MySQL入门 (九) : 子查询 Subquery
2016-08-30 02:26 44541 一个叙述中的查询叙述 子查询(subquery)是一 ... -
PHP: 用readonly取代disabled来获取input值 submit a disabled input in a form could not ge
2016-08-30 02:21 2718The form is like below; <f ... -
PHP7革新与性能优化
2016-08-30 02:20 2155有幸参与2015年的PHP技 ... -
Mysql: 图解 inner join、left join、right join、full outer join、union、union all的区别
2016-08-18 06:03 3131对于SQL的Join,在学习起来可能是比较乱的。我们知道, ... -
Comet 反Ajax: 基于jQuery与PHP实现Ajax长轮询(LongPoll)
2016-08-18 06:00 1386传统的AJAX轮询方式,客服端以用户定义的时间间隔去服务器上 ... -
PHP:ServerPush (Comet推送) 技术的探讨
2016-08-18 05:58 1048PHP中Push(推送)技术的探讨 [http://vi ... -
PHP: 手把手编写自己的 MVC 框架实例教程
2016-08-16 05:33 18221 什么是MVC MVC模式(Model-View-Con ... -
PHP5: mysqli 插入, 查询, 更新和删除 Insert Update Delete Using mysqli (CRUD)
2016-07-29 12:55 1760原文: PHP5: mysqli 插入, 查询, 更新 ... -
MongoDB 教程索引 (附有视频)
2016-07-27 10:54 756MongoDB 教程索引 MongoDB 教程一: ... -
Node.js 模块之Nimble流程控制
2016-07-18 12:59 1087NodeJS异步的特性有时候 ... -
Node.js web应用模块之Supervisor
2016-07-18 12:56 2335在开发或调试Node.js应 ...
相关推荐
本文将深入探讨如何使用PHP来实现数据导出成CSV文件。 首先,我们需要了解CSV文件的基本结构。CSV文件是以逗号分隔的数据值,每一行代表一条记录,每个字段之间用逗号隔开。如果字段中包含逗号或其他特殊字符,通常...
在PHP中,导出CSV文件是一项常见的任务,特别是在数据处理和报表生成的场景下。CSV(Comma Separated Values)格式是一种简单且广泛使用的数据交换格式,它将数据以逗号分隔,易于读取和导入到各种电子表格程序如...
json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to csv最新代码json to ...
在PHP中生成CSV文件是一项常见的任务,特别是在数据导出、报表生成或数据分析的场景下。CSV(Comma Separated Values)格式是一种通用的数据交换格式,因其简单性和易读性而广受欢迎。以下将详细介绍如何使用PHP来...
标题“csvToarff.zip”指的是一个压缩包文件,其中包含了一个用于将CSV(逗号分隔值)格式的数据转换成ARFF(Attribute-Relation File Format)格式的MATLAB代码。ARFF是Weka数据挖掘工具所采用的一种数据存储格式,...
在PHP中操作CSV(Comma Separated Values)文件是一项常见的任务,特别是在数据导入、导出、分析或存储的过程中。CSV因其简单性和通用性而被广泛使用。本文将深入探讨如何使用PHP来处理CSV文件。 首先,打开和读取...
在PHP中处理CSV(Comma Separated Values)文件是一项常见的任务,特别是在数据导入、导出或数据分析场景下。CSV文件以其简洁的格式和广泛的兼容性而受到青睐。本篇文章将详细探讨如何使用PHP来读取和操作CSV文件,...
在PHP中,CSV(Comma Separated Values)文件是一种常见的数据交换格式,广泛用于数据导入和导出操作。CSV文件以其简单、通用的特性,使得它成为与各种数据库、电子表格软件(如Microsoft Excel)之间交换数据的理想...
导入CSV文件通常涉及到读取文件内容并将其转换为数组。PHP的`fgetcsv()`函数可以做到这一点。在connect.php或其他适当的文件中,你可以打开CSV文件,逐行读取并解析数据: ```php <?php $file = fopen('data.csv',...
File file = new File("path_to_your_csv_file.csv"); FileReader fr = new FileReader(file); BufferedReader br = new BufferedReader(fr); CsvReader reader = new CsvReader(br); ``` 3. **读取数据**:`...
标题"宏 csv to xlsx_csv_xlsx_源码"暗示了这是一个使用Excel宏来实现自动转换过程的模板。宏是VBA(Visual Basic for Applications)编程语言的一部分,它允许用户自定义Excel的功能,实现自动化任务。在这个场景下...
CSV TO MSSQL CSV 导入MSSQL 2005 并且简单处理文件
CSV文件转化KML文件工具是一种实用程序,专为在谷歌地球上创建动态轨迹而设计。它允许用户将包含纬度、经度和高度信息的CSV(逗号分隔值)文件转换为KML(Keyhole Markup Language)文件,KML是Google Earth和其他...
假设我们有一个名为`data.csv`的文件,位于`/path/to/data.csv`,我们可以这样读取: ```python df_csv = spark.read.format("csv") \ .option("header", "true") \ .option("inferSchema", "true") \ .load("/...
在IT行业中,CSV(Comma Separated Values)文件是一种广泛使用的数据交换格式,因其简单、通用而备受青睐。ThinkPHP是中国流行的PHP框架之一,它提供了一系列功能强大的工具,包括处理CSV文件的导入与导出。在...
解决多语言导出乱码,主要进行导出编码格式设定,试过很多次已经OK
CSV数据操作的工具包-含合并CSV文件、Excel转CSV、CSV转XLSX、统计CSV行数、重命名表头、选择和重排CSV列等功能 【项目简介】 用于 CSV 数据操作的工具包。它提供了多种功能,包括合并 CSV 文件、将 Excel 转换为 CSV...
标题“Import csv to mysql”指的是将CSV(逗号分隔值)文件导入到MySQL数据库的过程。这个过程在数据处理和数据分析中非常常见,因为它允许用户将结构化数据从文本文件轻松转移到关系型数据库中,例如MySQL。这篇...
CSV(Comma Separated Values)是一种常见的数据存储格式,它以逗号分隔各个字段,广泛用于数据交换、数据分析和数据库导入导出等场景。在处理CSV文件时,Excel通常是首选工具,但由于Excel的一些默认设置和特性,...
"CSV to Entity" 框架是一个专为开发人员设计的工具,它能够帮助程序员快速地将CSV文件转换为C#或VB.NET中的实体类。这个框架的核心功能是自动化生成代码,使得数据操作变得更加高效和便捷。它不仅减少了手动编写类...