链接:php导出到Excel 或 CSV

CSV 直译的就是 逗号分隔值

 

顾名思义,就是用英文的 "," 做分割。 CSV 导入mysql 数据库的核心原理也就在于此。

 

我们将会用到一个关键函数 fgetcsv(),它的解释如下:

 

fgetcsv() 函数从文件指针中读入一行并解析 CSV 字段。

 

与 fgets() 类似,不同的是 fgetcsv() 解析读入的行并找出 CSV 格式的字段,然后返回一个包含这些字段的数组。

fgetcsv() 出错时返回 FALSE,包括碰到文件结束时。

 

注释: 从 PHP 4.3.5 起,fgetcsv() 的操作是二进制安全的。

 

用法:

 

fgetcsv(file,length,separator,enclosure)



file

必需。规定要检查的文件。

length

可选。规定行的最大长度。必须大于 CVS 文件内最长的一行。

在 PHP 5 中该参数是可选的。在 PHP 5 之前是必需的。

如果忽略(在 PHP 5.0.4 以后的版本中设为 0)该参数的话,那么长度就没有限制,不过可能会影响执行效率。

separator

可选。设置字段分界符(只允许一个字符),默认值为逗号。

enclosure

可选。设置字段环绕符(只允许一个字符),默认值为双引号。

该参数是在 PHP 4.3.0 中添加的。

 

 

完整代码:

 

<?php
	// 定义获取时间函数
	function getmicrotime(){
		list($usec, $sec) = explode(' ',microtime());
		return ((float)$usec + (float)$sec);
	}

	$time_start = getmicrotime();


	// 连接数据库

	/*
	include("database_class.php");
	$db = new Database;
	*/

	mysql_connect('localhost','root','root'); 
	mysql_select_db('test');

	// 操作csv
	$handle = fopen ('test.csv','r');
	$sql="insert into `test` (`id`,`name`,`sex`,`nation`) values ('',";
		while ($data = fgetcsv ($handle)) {
		   $num = count ($data);
		   for ($i=0; $i<$num; $i++) {
			   if($i == $num-1){
				   $sql .= "'".$data[$i]."')";
				   break;
				}
			   $sql .= "'".$data[$i]."',";
		   }

			print '<br>';
			echo $sql.'<br>';

			mysql_query($sql);

			echo 'sql语句执行成功!<br>';
			$sql="insert into `test` (`id`,`name`,`sex`,`nation`) values ('',";
		}

	fclose ($handle);

	// 显示执行时间
	$time_end = getmicrotime();
	$time = $time_end - $time_start;
	echo "程式执行时间:".$time."秒<br>";

	// 显示数据库结果
	$result = mysql_query('select * from `test`');
	while($row = mysql_fetch_array($result)){
		echo $row['id'],'<br>',$row['name'],'<br>',$row['sex'],'<br>',$row['nation'],'<br>';
	}

 

 

 

fgetcsv 例子

<?php

$file = fopen("contacts.csv","r");

while(! feof($file))
  {
  print_r(fgetcsv($file));
  }

fclose($file);

?>

CSV 文件:

 


George, John, Thomas, USA James, Adrew, Martin, USA


 

输出类似:

 

Array 
( 
[0] => George
[1] => John 
[2] => Thomas
[3] => USA

Array
(
[0] => James
[1] => Adrew
[2] => Martin
[3] => USA
)