ThinkPhp3.2.3 使用phpExcel导入数据

 1 public function uploadExcel(){
 2      if (!empty($_FILES)){  
 3             $upload = new \Think\Upload();                      // 实例化上传类  
 4             $upload->maxSize   =     10485760000 ;                 // 设置附件上传大小  
 5             $upload->exts      =     array('xls','xlsx');       // 设置附件上传类型  
 6             $upload->rootPath  = './Public/excel/';             // 设置附件上传根目录  
 7             $upload->autoSub   = false;                         // 将自动生成以photo后面加时间的形式文件夹,关闭  
 8             // 上传文件  
 9             $info   =   $upload->upload();                                   // 上传文件  
10             $exts   = $info['file']['ext'];                                 // 获取文件后缀  
11             $filename = $upload->rootPath.$info['file']['savename'];        // 生成文件路径名  
12             if(!$info) {                                                     // 上传错误提示错误信息  
13                 $this->error($upload->getError());   
14             }else{                                                           // 上传成功  
15                 import("Org.Util.PHPExcel");                                 // 导入PHPExcel类库,因为PHPExcel没有用命名空间,只能import导入  
16                 $PHPExcel = new \PHPExcel();                                 // 创建PHPExcel对象,注意,不能少了\  
17                 if ($exts == 'xls') {                                        // 如果excel文件后缀名为.xls,导入这个类  
18                     import("Org.Util.PHPExcel.Reader.Excel5");  
19                     $PHPReader = new \PHPExcel_Reader_Excel5();  
20                 } else   
21  
22                     if ($exts == 'xlsx') {  
23                         import("Org.Util.PHPExcel.Reader.Excel2007");  
24                         $PHPReader = new \PHPExcel_Reader_Excel2007();  
25  
26                     }  
27                 // var_dump($filename);exit;
28                 $PHPExcel=$PHPReader->load($filename);  
29                 $currentSheet = $PHPExcel->getSheet(0);                      // 获取表中的第一个工作表,如果要获取第二个,把0改为1,依次类推  
30                 $allRow = $currentSheet->getHighestRow();                    // 获取总行数
31                 // echo $allRow;exit;
32                 $data=array();  
33                
34                for ($i = 2; $i <= $allRow; $i++) {  
35                     $data['province'] =$PHPExcel->getActiveSheet()->getCell("A" . $i)->getValue();  
36                     $data['city'] =$PHPExcel->getActiveSheet()->getCell("B" .$i)->getValue();  
37                     $data['vocation'] =$PHPExcel->getActiveSheet()->getCell("C" .$i)->getValue();  
38                     $data['age'] = $PHPExcel->getActiveSheet()->getCell("D". $i)->getValue();  
39                     $data['sex'] =$PHPExcel->getActiveSheet()->getCell("E" .$i)->getValue();
40                     $data['company'] =$PHPExcel->getActiveSheet()->getCell("F" . $i)->getValue();  
41                     $data['phone'] =(string)$PHPExcel->getActiveSheet()->getCell("G" . $i)->getValue();  
42                     $data['other'] =$PHPExcel->getActiveSheet()->getCell("H" . $i)->getValue();  
43                     $ex=M('phone')->add($data);  
44               }  
45               // var_dump($data_p);exit;
46             if($ex){                                           
47                $this->success("导入成功",U('Phone/index'));  
48             }else{  
49                 $this->error("导入失败,原因可能是excel表中格式错误",U('Phone/add'),"5");// 提示错误  
50                }  
51             }  
52         }else {  
53           $this->display('Phone/add');   
54         }      
55     }  
56 --------------------- 
57 作者:limingyue0312 
58 来源:CSDN 
59 原文:https://blog.csdn.net/limingyue0312/article/details/81240017 

 

posted @ 2018-12-15 14:19  原来是个帅小伙  阅读(789)  评论(0编辑  收藏  举报