阅读模式:

比phpexcel还要简单的excel CSV 一键导入数据到数据库

查看:5124  回复:0  类型:  来源:php自学网,moons blog  标签 php

代码如下:

思路:先上车csv文件。再读取临时文件的内容。开始遍历内容,进行拼接,最后通过一条sql语句一次把所有拼接好的数据写入数据库。

<?php   
 
 if($_SERVER['REQUEST_METHOD']=='POST'){
      function input_csv($handle) {   
          $out = array ();   
          $n = 0;    
          while ($data = fgetcsv($handle, 10000)) {     
                $num = count($data);     
                 for ($i = 0; $i < $num; $i++) {       
                     $out[$n][$i] = $data[$i];     
                   }      
                   $n++;   
                  }    
                   return $out;  
         }      
         $file = $_FILES['file']['tmp_name'];   
          if(empty($file)){    
                 echo "<script>alert('请选择文件');</script>";    
               }    
            $handle = fopen($file,'r');   
            $result = input_csv($handle);//解析csv   
            $len_result = count($result);   
            if($len_result == 0){      
                      echo "<script>alert('没有任何数据');</script>";     
             }else{     
                   for($i=1;$i<$len_result;$i++){      
                                $sort_num = iconv('gb2312','utf-8',$result[$i][0]);    
                                $sf = trim(iconv('gb2312','utf-8',$result[$i][1]));    
                                $cs = trim(iconv('gb2312','utf-8',$result[$i][2]));      
                                $title = iconv('gb2312','utf-8',$result[$i][3]);    
                                $add = iconv('gb2312','utf-8',$result[$i][4]);     
                                $ct = iconv('gb2312','utf-8',$result[$i][5]);     
                                $phone = iconv('gb2312','utf-8',$result[$i][6]); 
                                $flags='i';
                                $sql = "select id from category where parent_id=(SELECT id FROM category WHERE category_name = '{$sf}') and category_name = '{$cs}'";
                                $tab_res = $nsodb->get_row($sql,ARRAY_A);
                                $cid = $tab_res['id'];            
                                $publisher=$_SESSION['admin'];            
                                $data .= "(16,'$cid','$title','$flags','$phone','$sort_num',now(),'$publisher','$add','$ct'),";             
                           }                  
                           $data = substr($data,0,-1);         
                           fclose($handle);                  
                           $ares = mysql_query("insert into content (channel_id,category_id,title,flags,descriptions,sort_num,add_time,publisher,details,sketch) values $data ");                  
                                  if($ares){            
                                      echo "<script>alert('导入成功');</script>";             
                                  }else{            
                                      echo "<script>alert('导入失败');</script>";         
                                  }               
          }         
    }
 ?>

    
    参考原文:http://www.92csz.com/47/1238.html


分享到:
0 0

*有问题之处烦请在评论中指出非常感谢!
不是我想要的内容,继续搜索:

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
web项目高并发量网站解决方案   阅读:4302用php从1加到100的值   阅读:7967ajax+php 实现一个简单的在线聊天室功能(附带源码)   阅读:8714shell脚本统计当前服务器并发连接数   阅读:6733linux教程,鸟哥私房菜(pdf全集)   阅读:9141centos 7 开启网络   阅读:6489centos 7 安装 nginx-1.11.10   阅读:7975“米粉节”背后的故事——小米网抢购系统开发实践   阅读:3833centos 7 开启网络   阅读:6489最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:10351给网站添加一键qq登录的功能   阅读:6869nginx安装mysql和json模块   阅读:4300phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:11684面试都会问你为什么你从上一家公司离职的真实意思   阅读:10539最简单的Banner轮播淡入淡出效果代码及实现思路(附带源码)   阅读:12552封装php redis缓存操作类   阅读:8507mysql数据一键导出到csv文件   阅读:5271shell发送邮件脚本   阅读:6882linux top命令详解   阅读:8786mongodb设置shell开机启动脚本   阅读:9288crontab+shell脚本实现定时备份mysql数据库   阅读:7212centos 7 安装 mysql-5.7   阅读:6469centos 7 添加 redis 3.2.9 开机启动脚本   阅读:8907php 使用 smtp.php 类在线发送邮件功能   阅读:5191php 读取和设置redis的键值   阅读:6919封装php redis缓存操作类   阅读:8507centos 7 修改系统屏幕分辨率   阅读:42336php打印九九加法表   阅读:9362phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:11684一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:125033centos7开启交换内存   阅读:10243面试都会问你为什么你从上一家公司离职的真实意思   阅读:10539TCP的三次握手(建立连接)和四次挥手(关闭连接)   阅读:2922php生成二维码   阅读:6427PHP 鸟哥:我也曾经是“不适合”编程的人   阅读:13812PHP 鸟哥:我也曾经是“不适合”编程的人   阅读:13812人性漫画:打工与创业的残酷区别   阅读:4491php 获取当前前后年、月、星期、日、时分秒的时间   阅读:6254web项目高并发量网站解决方案   阅读:4302“米粉节”背后的故事——小米网抢购系统开发实践   阅读:3833phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:11684Nginx 配置文件详解   阅读:4342TCP的三次握手(建立连接)和四次挥手(关闭连接)   阅读:2922给 centos 7 安装桌面环境   阅读:16321十张GIF让你弄懂递归等概念   阅读:5696HTTP 1.1 协议详解   阅读:9997php压缩页面的html代码一行显示   阅读:6779一步步带你,如何网站架构   阅读:3806给 centos 7 安装桌面环境   阅读:16321php中地址引用&的真正理解-变量引用、函数引用、对象引用   阅读:5258