CSV 导入mysql 数据库

链接:php导出到Excel 或 CSV


CSV 直译的就是 逗号分隔值

 

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

 

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

 

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

 

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

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

 

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

 

用法:

 

Php代码   收藏代码
  1. fgetcsv(file,length,separator,enclosure)  
 
  
file必需。规定要检查的文件。
length

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

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

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

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

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

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

 

 

完整代码:

 

Php代码   收藏代码
  1. <?php  
  2.     // 定义获取时间函数  
  3.     function getmicrotime(){  
  4.         list($usec$sec) = explode(' ',microtime());  
  5.         return ((float)$usec + (float)$sec);  
  6.     }  
  7.   
  8.     $time_start = getmicrotime();  
  9.   
  10.   
  11.     // 连接数据库  
  12.   
  13.     /* 
  14.     include("database_class.php"); 
  15.     $db = new Database; 
  16.     */  
  17.   
  18.     mysql_connect('localhost','root','root');   
  19.     mysql_select_db('test');  
  20.   
  21.     // 操作csv  
  22.     $handle = fopen ('test.csv','r');  
  23.     $sql="insert into `test` (`id`,`name`,`sex`,`nation`) values ('',";  
  24.         while ($data = fgetcsv ($handle)) {  
  25.            $num = count ($data);  
  26.            for ($i=0; $i<$num$i++) {  
  27.                if($i == $num-1){  
  28.                    $sql .= "'".$data[$i]."')";  
  29.                    break;  
  30.                 }  
  31.                $sql .= "'".$data[$i]."',";  
  32.            }  
  33.   
  34.             print '<br>';  
  35.             echo $sql.'<br>';  
  36.   
  37.             mysql_query($sql);  
  38.   
  39.             echo 'sql语句执行成功!<br>';  
  40.             $sql="insert into `test` (`id`,`name`,`sex`,`nation`) values ('',";  
  41.         }  
  42.   
  43.     fclose ($handle);  
  44.   
  45.     // 显示执行时间  
  46.     $time_end = getmicrotime();  
  47.     $time = $time_end - $time_start;  
  48.     echo "程式执行时间:".$time."秒<br>";  
  49.   
  50.     // 显示数据库结果  
  51.     $result = mysql_query('select * from `test`');  
  52.     while($row = mysql_fetch_array($result)){  
  53.         echo $row['id'],'<br>',$row['name'],'<br>',$row['sex'],'<br>',$row['nation'],'<br>';  
  54.     }  
 

 

 

 

fgetcsv 例子

Php代码   收藏代码
  1. <?php  
  2.   
  3. $file = fopen("contacts.csv","r");  
  4.   
  5. while(! feof($file))  
  6.   {  
  7.   print_r(fgetcsv($file));  
  8.   }  
  9.   
  10. fclose($file);  
  11.   
  12. ?>   
 

CSV 文件:

 

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

 

输出类似:

 

Php代码   收藏代码
  1. Array   
  2. (   
  3. [0] => George  
  4. [1] => John   
  5. [2] => Thomas  
  6. [3] => USA  
  7.   
  8. Array  
  9. (  
  10. [0] => James  
  11. [1] => Adrew  
  12. [2] => Martin  
  13. [3] => USA  
  14. )  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值