• TP6框架--EasyAdmin学习笔记:Excel表单导入数据库


    这是我写的学习EasyAdmin的第四章,这一章我给大家分享下Excel表单导入数据库的全流程需要怎么处理并提供案例

    首先给大家看下这个功能的原理,下面是PHP连接打印机的代码

        public function uplExcel(Request $request)
        {
            if (!empty($_FILES['excel']['name'])) {
                $fileName = $_FILES['excel']['name'];    //得到文件全名
                $dotArray = explode('.', $fileName);    //把文件名安.区分,拆分成数组
                $type = end($dotArray);
    
                if ($type != "xls" && $type != "xlsx") {
                    $ret['res'] = "0";
                    $ret['msg'] = "不是Excel文件,请重新上传!";
                    return json_encode($ret);
                }
    
                //取数组最后一个元素,得到文件类型
                $uploaddir = "../uploads2/" . date("Y-m-d") . '/';//设置文件保存目录 注意包含
                if (!file_exists($uploaddir)) {
                    mkdir($uploaddir, 0777, true);
                }
    
                $path = $uploaddir . md5(uniqid(rand())) . '.' . $type; //产生随机文件名
                //$path = "images/".$fileName; //客户端上传的文件名;
                //下面必须是tmp_name 因为是从临时文件夹中移动
                move_uploaded_file($_FILES['excel']['tmp_name'], $path); //从服务器临时文件拷贝到相应的文件夹下
    
                $file_path = $path;
                if (!file_exists($path)) {
                    $ret['res'] = "0";
                    $ret['msg'] = "上传文件丢失!" . $_FILES['excel']['error'];
                    return json_encode($ret);
                }
    
                //文件的扩展名
                $ext = strtolower(pathinfo($path, PATHINFO_EXTENSION));
                if ($ext == 'xlsx') {
                    $objReader = PHPExcel_IOFactory::createReader('Excel2007');
                    $objPHPExcel = $objReader->load($file_path, 'utf-8');
                } elseif ($ext == 'xls') {
                    $objReader = PHPExcel_IOFactory::createReader('Excel5');
                    $objPHPExcel = $objReader->load($file_path, 'utf-8');
                }
    
                $sheet = $objPHPExcel->getSheet(0);
                $highestRow = $sheet->getHighestRow(); // 取得总行数
                $highestColumn = $sheet->getHighestColumn(); // 取得总列数
                $ar = array();
                $i = 0;
                $importRows = 0;
                for ($j = 2; $j <= $highestRow; $j++) {
                    $importRows++;
    
                    $realName = (string)$objPHPExcel->getActiveSheet()->getCell("A$j")->getValue();//需要导入的realName
                    $phone = (string)$objPHPExcel->getActiveSheet()->getCell("B$j")->getValue();   //需要导入的phone
                    $company = (string)$objPHPExcel->getActiveSheet()->getCell("C$j")->getValue(); //需要导入的company
                    $job = (string)$objPHPExcel->getActiveSheet()->getCell("D$j")->getValue();     //需要导入的job
                    $email = (string)$objPHPExcel->getActiveSheet()->getCell("E$j")->getValue();   //需要导入的email
                    $ret['mdata'] = $this->addMemb($phone, $realName, $company, $job, $email);//这里就是我的数据库添加操作定义的一个方法啦,对应替换为自己的
    
                    if ($ret['mdata'] && !is_Bool($ret['mdata'])) {
                        $ar[$i] = $ret['mdata'];
                        $i++;
                    }
                }
                if ($i > 0) {
                    $ret['res'] = "0";
                    $ret['errNum'] = $i;
                    $ret['allNum'] = $importRows;
                    $ret['sucNum'] = $importRows - $i;
                    $ret['mdata'] = $ar;
                    $ret['msg'] = "导入完毕!";
                    return json_encode($ret);
                }
                $ret['res'] = "1";
                $ret['allNum'] = $importRows;
                $ret['errNum'] = 0;
                $ret['sucNum'] = $importRows;
                $ret['mdata'] = "导入成功!";
                return json_encode($ret);
            } else {
                $ret['res'] = "0";
                $ret['msg'] = "上传文件失败!";
                return json_encode($ret);
            }
        }  

    大家可以看到,正常的Excel导入流程分为上传+解析+数据处理+录入四部,整体的流程是调用对应的接口和插件,而使用TP框架,会直接帮我们绕过上传流程,我们使用PHPEXCEL插件直接到解析,具体代码如下:

    下载PHPExcel放到vendor下,并在后台接口中导入

    public function save(){
           if(request() -> isPost())
           {
               vendor("PHPExcel.PHPExcel"); 
               $objPHPExcel =new PHPExcel();
     
               //var_dump($objPHPExcel);die;
               //获取表单上传文件
               $file = request()->file('excel');
               //print_r($file);die;
               $info = $file->validate(['ext' => 'xlsx'])->move(ROOT_PATH . 'public/file');  //上传验证后缀名,以及上传之后移动的地址  
     
               if($info)
               {
     
                   $exclePath = $info->getSaveName();  //获取文件名
                   $file_name = ROOT_PATH . 'public/file/' . DS . $exclePath;//上传文件的地址
                   $objReader =PHPExcel_IOFactory::createReader("Excel2007");
                   $obj_PHPExcel =$objReader->load($file_name, $encode = 'utf-8');  //加载文件内容,编码utf-8
                   $excel_array=$obj_PHPExcel->getSheet(0)->toArray();   //转换为数组格式
     
                   //print_r($excel_array);die;
                   array_shift($excel_array);  //删除第一个数组(标题);
                   $city = [];
                   $i=0;
                   foreach($excel_array as $k=>$v) {
     
                   	   $click_time  = strtotime($v[2]);//点击时间转为时间戳
                   	   $active_time = strtotime($v[2]);//激活时间转为时间戳
                       $city[$k]['adid']      = $v[0];
                       $city[$k]['idfa']      = $v[1];
                       $city[$k]['udid']      = $v[4];
                       $city[$k]['model']     = $v[5];
                       $city[$k]['os']        = $v[6];
                       $city[$k]['ip']        = $v[7];
                       $city[$k]['add_time']  = $click_time;
                       $city[$k]['act_time']  = $active_time;
     
                       $i++;
                   }
     
                  // print_r($city);die;
                   Db::name("check_udid")->insertAll($city);
               }else
               {
                   echo $file->getError();
               }
           }
       } 

    EasyAdmin虽然基于TP6,在使用的过程中我发现,它不需要自己写以上方法,框架自带一些写好的上传方法,直接使用即可,具体方法如下:

    在使用的php中导入:

    use jianyanexcelExcel;

    调用即可:

                $file = request()->file('file');
                ini_set('memory_limit','1024M');
                $data =  Excel::import($file);        

    如果本文对你有所帮助,麻烦你点个赞,下一章讲下如何自制搜索框并进行各种参数调整。

  • 相关阅读:
    Java四种内部类
    Java多态详解
    为啥java要使用 set ()和get()方法---封装
    Python---django轻量级框架
    java 读取数据库数据转化输出XML输出在jsp页面
    操作系统专栏
    learn more ,study less(三):超越整体性学习
    learn more ,study less(二):整体性学习技术(下)
    learn more ,study less(二):整体性学习技术(上)
    Spring博客专栏
  • 原文地址:https://www.cnblogs.com/smileZAZ/p/14818767.html
Copyright © 2020-2023  润新知