ThinkPhp3.2.3 使用phpExcel匯入資料
阿新 • • 發佈:2018-12-15
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