`
天梯梦
  • 浏览: 13729348 次
  • 性别: Icon_minigender_2
  • 来自: 洛杉矶
社区版块
存档分类
最新评论

php csv to array (csv 转数组)

 
阅读更多

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('&amp;','&quot;','&#039;','&lt;','&gt;'),$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数据导出成csv

    本文将深入探讨如何使用PHP来实现数据导出成CSV文件。 首先,我们需要了解CSV文件的基本结构。CSV文件是以逗号分隔的数据值,每一行代表一条记录,每个字段之间用逗号隔开。如果字段中包含逗号或其他特殊字符,通常...

    php导出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 csv最新代码json to ...

    php生成csv文件

    在PHP中生成CSV文件是一项常见的任务,特别是在数据导出、报表生成或数据分析的场景下。CSV(Comma Separated Values)格式是一种通用的数据交换格式,因其简单性和易读性而广受欢迎。以下将详细介绍如何使用PHP来...

    csvToarff.zip

    标题“csvToarff.zip”指的是一个压缩包文件,其中包含了一个用于将CSV(逗号分隔值)格式的数据转换成ARFF(Attribute-Relation File Format)格式的MATLAB代码。ARFF是Weka数据挖掘工具所采用的一种数据存储格式,...

    php操作csv文件

    在PHP中操作CSV(Comma Separated Values)文件是一项常见的任务,特别是在数据导入、导出、分析或存储的过程中。CSV因其简单性和通用性而被广泛使用。本文将深入探讨如何使用PHP来处理CSV文件。 首先,打开和读取...

    php记取csv文件

    在PHP中处理CSV(Comma Separated Values)文件是一项常见的任务,特别是在数据导入、导出或数据分析场景下。CSV文件以其简洁的格式和广泛的兼容性而受到青睐。本篇文章将详细探讨如何使用PHP来读取和操作CSV文件,...

    php导入导出CSV实例

    在PHP中,CSV(Comma Separated Values)文件是一种常见的数据交换格式,广泛用于数据导入和导出操作。CSV文件以其简单、通用的特性,使得它成为与各种数据库、电子表格软件(如Microsoft Excel)之间交换数据的理想...

    PHP导出导入csv

    导入CSV文件通常涉及到读取文件内容并将其转换为数组。PHP的`fgetcsv()`函数可以做到这一点。在connect.php或其他适当的文件中,你可以打开CSV文件,逐行读取并解析数据: ```php &lt;?php $file = fopen('data.csv',...

    javacsv_CsvReader:解析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_源码

    标题"宏 csv to xlsx_csv_xlsx_源码"暗示了这是一个使用Excel宏来实现自动转换过程的模板。宏是VBA(Visual Basic for Applications)编程语言的一部分,它允许用户自定义Excel的功能,实现自动化任务。在这个场景下...

    CSV TO MSSQL

    CSV TO MSSQL CSV 导入MSSQL 2005 并且简单处理文件

    CSV文件转化kml文件工具

    CSV文件转化KML文件工具是一种实用程序,专为在谷歌地球上创建动态轨迹而设计。它允许用户将包含纬度、经度和高度信息的CSV(逗号分隔值)文件转换为KML(Keyhole Markup Language)文件,KML是Google Earth和其他...

    thinkphp下 导入导出csv文件

    在IT行业中,CSV(Comma Separated Values)文件是一种广泛使用的数据交换格式,因其简单、通用而备受青睐。ThinkPHP是中国流行的PHP框架之一,它提供了一系列功能强大的工具,包括处理CSV文件的导入与导出。在...

    PHP导出 xls CSV

    解决多语言导出乱码,主要进行导出编码格式设定,试过很多次已经OK

    Import csv to mysql

    标题“Import csv to mysql”指的是将CSV(逗号分隔值)文件导入到MySQL数据库的过程。这个过程在数据处理和数据分析中非常常见,因为它允许用户将结构化数据从文本文件轻松转移到关系型数据库中,例如MySQL。这篇...

    CSV编辑器,完美保存CSV格式

    CSV(Comma Separated Values)是一种常见的数据存储格式,它以逗号分隔各个字段,广泛用于数据交换、数据分析和数据库导入导出等场景。在处理CSV文件时,Excel通常是首选工具,但由于Excel的一些默认设置和特性,...

    CSV to Entity

    "CSV to Entity" 框架是一个专为开发人员设计的工具,它能够帮助程序员快速地将CSV文件转换为C#或VB.NET中的实体类。这个框架的核心功能是自动化生成代码,使得数据操作变得更加高效和便捷。它不仅减少了手动编写类...

    heart.csv、gisette.csv+elevators.csv+glass.csv

    这里的"heart.csv、gisette.csv+elevators.csv+glass.csv"提到的三个CSV文件,分别代表三个不同的数据集,可以用于训练和评估不同的机器学习模型。 1. **heart.csv**: 这个数据集通常用于预测心脏病的发生。它可能...

    XlS批量生成CSV 多个CSV合并为1个CSV

    在标题“XlS批量生成CSV 多个CSV合并为1个CSV”中,涉及到的主要知识点是Excel文件(XLS)的批处理转换以及多个CSV文件的合并。这些操作在数据分析、报表整理、数据库导入等场景中非常实用。 首先,我们需要理解XLS...

Global site tag (gtag.js) - Google Analytics