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
人生得意须尽欢,莫使金樽空对月.