PHP 通过PHPexcel实现excel导入mysql (此示例没有用到PHP框架)

10 篇文章 0 订阅
7 篇文章 0 订阅

1.首先下载PHPExcel插件,官网链接: https://codeplexarchive.blob.core.windows.net/archive/projects/PHPExcel/PHPExcel.zip 

<?php

header("content-type:text/html;charset=utf-8"); 

$con =mysqli_connect("127.0.0.1","用户名","密码","库名")or die("Mysql连接失败".mysqli_connect_error());

 mysqli_query($con," SET NAMES utf-8");

    $filePath = './upload/';
    require_once 'PHPExcel.php';
    require_once 'PHPExcel/IOFactory.php';
    require_once 'PHPExcel/Reader/Excel5.php';
    //以上三步加载phpExcel的类

   $file = $_FILES['file']['name'];
   $filetempname = $_FILES['file']['tmp_name'];

    $filename=explode(".",$file);//把上传的文件名以“.”好为准做一个数组。 

    $time=date("Y-m-d-H-i-s");//去当前上传的时间 

    $filename[0]=$time;//取文件名t替换 

    $name=implode(".",$filename); //上传后的文件名 

    $uploadfile=$filePath.$name;//上传后的文件名地址 

    $result=move_uploaded_file($filetempname,$uploadfile);

    if($result){ //如果上传文件成功,就执行导入excel操作

        $objPHPExcel = PHPExcel_IOFactory::load($uploadfile);

        $sheet = $objPHPExcel->getSheet(0); 

        $highestRow = $sheet->getHighestRow(); // 取得总行数 

        $highestColumn = $sheet->getHighestColumn(); // 取得总列数


          //循环读取excel文件,读取一条,插入一条
        $str = "";
        for($j=2;$j<=$highestRow;$j++){  //因为Excel第一行和数据表中的字段相对照,所以$j=2代表从Excel的第二行开始。
            for($k='A';$k<=$highestColumn;$k++){ 
                $str .= iconv("UTF-8","GBK",$objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue()).'\\';//读取单元格
            } 

             $strs = explode("\\",$str);

             $da=iconv('GBK','UTF-8',$strs[2]);//防止中文乱码

             $sql = "insert into duty (ZW_ID,Z_ID,zw_name) values('".$strs[0]."','".$strs[1]."','".$da."')";

            $res= mysqli_query($con,$sql);

            set_time_limit(10000); //数据量大时防止超时

            if(!$res){

                return false;
            }

            $str = "";
        } 
        unlink($uploadfile); //删除上传的excel文件

        $msg = "导入成功!";

     }else{

        $msg = "导入失败!";
}

echo $msg;

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

❀想容

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值