PHP将mysql数据导入Excel表中

有时写程序时后台要求把大量数据导入数据库中,比如考试成绩、电话簿等一般都是存放在excel中的数据,这时我们可把excel导出成csv文件,然后通过以下程序即可批量导入数据到数据库中,上传cvs并导入到数据库中,测试成功(部分代码不规范,如PHP_SELF那里要改写成$_SERVER["PHP_SELF"] )

 
 
  1. <?php      
  2. $fname = $_FILES['MyFile']['name'];      
  3. $do = copy($_FILES['MyFile']['tmp_name'],$fname);      
  4. if ($do)       
  5. {       
  6.     echo"导入数据成功<br>";       
  7. else {      
  8.     echo "";       
  9. }      
  10. ?>      
  11. <form ENCTYPE="multipart/form-data" ACTION="<?php echo"".$PHP_SELF.""; ?>" METHOD="POST">       
  12.     <p>导入CVS数据  <input NAME="MyFile" TYPE="file"> <input VALUE="提交" TYPE="submit">       
  13.     </p>      
  14. </form>       
  15. <?      
  16. error_reporting(0);      
  17. //导入CSV格式的文件      
  18. $connect=mysql_connect("localhost","a0530093319","123456"or die("could not connect to database");      
  19. mysql_select_db("a0530093319",$connector die (mysql_error());      
  20. $fname = $_FILES['MyFile']['name'];      
  21. $handle=fopen("$fname","r");      
  22. while($data=fgetcsv($handle,10000,","))                 
  23. {      
  24.     $q="insert into test (code,name,date) values ('$data[0]','$data[1]','$data[2]')";      
  25.     mysql_query($qor die (mysql_error());      
  26.                                            
  27. }      
  28. fclose($handle);      
  29. ?> 

用php将数据库导出成excel,测试完全成功

 
 
  1. <?php    
  2. $DB_Server = "localhost";      
  3. $DB_Username = "root";      
  4. $DB_Password = "";      
  5. $DB_DBName = "ishop";      
  6. $DB_TBLName = "oi_mall_payment";      
  7.      
  8. $savename = date("YmjHis");   
  9. $Connect = @mysql_connect($DB_Server$DB_Username$DB_Passwordor die("Couldn't connect.");      
  10. mysql_query("Set Names 'gbk'");  
  11. $file_type = "vnd.ms-excel";      
  12. $file_ending = "xls";  
  13. header("Content-Type: application/$file_type;charset=big5");   
  14. header("Content-Disposition: attachment; filename=".$savename.".$file_ending");      
  15. //header("Pragma: no-cache");         
  16.      
  17. $now_date = date("Y-m-j H:i:s");       
  18. $title = "数据库名:$DB_DBName,数据表:$DB_TBLName,备份日期:$now_date";       
  19.      
  20. $sql = "Select * from $DB_TBLName";       
  21. $ALT_Db = @mysql_select_db($DB_DBName$Connector die("Couldn't select database");      
  22. $result = @mysql_query($sql,$Connector die(mysql_error());    
  23.      
  24. echo("$title/n");       
  25. $sep = "/t";       
  26. for ($i = 0; $i < mysql_num_fields($result); $i++) {  
  27.     echo mysql_field_name($result,$i) . "/t";       
  28. }       
  29. print("/n");       
  30. $i = 0;       
  31. while($row = mysql_fetch_row($result)) {       
  32.     $schema_insert = "";  
  33.     for($j=0; $j<mysql_num_fields($result);$j++) {       
  34.         if(!isset($row[$j]))       
  35.             $schema_insert .= "NULL".$sep;       
  36.         elseif ($row[$j] != "")       
  37.             $schema_insert .= "$row[$j]".$sep;  
  38.         else       
  39.             $schema_insert .= "".$sep;       
  40.     }       
  41.     $schema_insert = str_replace($sep."$"""$schema_insert);       
  42.     $schema_insert .= "/t";       
  43.     print(trim($schema_insert));       
  44.     print "/n";       
  45.     $i++;       
  46. }       
  47. return (true);    
  48. ?> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值