此篇博客是本人的開山之篇,旨在記錄下平日裏的技術心得,同時若是碰巧能解決部分朋友的問題,那筆者感到很是榮幸。php
應業務的須要,須要將表格中的數據,進行EXCEL導出(支持分頁導出),同時又要使得EXCEL表格進行數據導入。所以本人在TP框架(3.2.3)下整合了PHPExcel。html
由於PHPExcel不支持命名空間,因此就用import導入了;數據庫
1.首先下載PHPExcel插件(這裏再也不贅述)。將PHPExcel.class.php文件連同PHPExcel文件夾放到 ThinkPHP\Library\Org\Util路徑下。bootstrap
2.view文件夾下建立Company文件夾,而後建立index.html(自行引入bootstrap框架)。表單部分的代碼以下:數組
1 <form method="post" action="__URL__/importExcel" enctype="multipart/form-data" name='myExcel'> 2 <input type="file" name="inexcel" value="導入"> 3 <button type="type" class="btn btn-primary" id="company-excel">導入Excel</button> 4 </form> 5 <br/> 6 <br/> 7 8 <form method="post" name="myform" action="__URL__/process"> 9 <button type="type" class="btn btn-primary" id="out-excel">導出Excel</button> 10 </form> 11 12 <div class="table-responsive"> 13 <table class="table table-striped table-hover"> 14 <thead> 15 <tr> 16 <th>ID</th> 17 <th>COMPANY_NAME_ZH</th> 18 <th>COMPANY_NAME_EN</th> 19 <th>LOCATION</th> 20 <th>OPTIONS</th> 21 </tr> 22 </thead> 23 <tbody> 24 <volist name="company_name" id="info"> 25 <tr> 26 <td>{$info.id}</td> 27 <td><a href="/Company/1454">{$info.name_zh}</a></td> 28 <td><a href="/Company/1454">{$info.name_en}</a></td> 29 <td>{$info.location}</td> 30 <td><a href="/Company/1454/editBaseInfo">EDIT</a></td> 31 </tr> 32 </volist> 33 </tbody> 34 </table> 35 </div> 36 37 <!--這裏是分頁部分--> 38 <div class='page_footer clearfix right'> 39 <ul class="pagination pagination-md"> 40 {$page} 41 </ul> 42 <div class='right' > 43 <input name='goto_input' class='form-control' size='3'> 44 <button class='btn btn-default' name='goto_button' link=''>Goto</button> 45 </div> 46 </div> 47
運行效果大體以下:瀏覽器
3.控制器部分:緩存
1 class CompanyController extends CommonController { 2 public function index(){ 3 $p = M('company'); 4 $count = $p->count(); 5 if($count){ 6 $page = new \Think\Page($count,10); 7 $page->setConfig('prev', '<span aria-hidden="true">上一頁</span>');//上一頁 8 $page->setConfig('next', '<span aria-hidden="true">下一頁</span>');//下一頁 9 $page->setConfig('first', '<span aria-hidden="true">首頁</span>');//第一頁 10 $page->setConfig('last', '<span aria-hidden="true">尾頁</span>');//最後一頁 11 $page->setConfig ( 'theme', '<li><a>當前%NOW_PAGE%/%TOTAL_PAGE%</a></li> %FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%' ); 12 $show = $page->show();//分頁顯示輸出 13 } 14 15 $list = $p->limit($page->firstRow.','.$page->listRows)->select(); 16 //將分頁數據存入緩存,固然這裏能夠換別種思路,好比在url上作文章,經過url獲取當前分頁數據,存入數組.....
F("abc", $list); 17 $this->assign('page',$show);//賦值分頁輸出 18 $this->assign('company_name',$list);//賦值數據集 19 $this->display(); 20 } 21 22 public function process(){ 23 header("Content-type:text/html;charset=utf-8"); 24 $cache_data = F("abc"); 25 $this->get_data($cache_data); 26 } 27 28 29 /* 導入excel文件的方法import() 30 * 1.導入文件 31 * 2.成功後調用file_import()方法->導入數據的方法 32 * 33 */ 34 public function importExcel(){ 35 header("Content-type:text/html;charset=utf-8"); 36 //判斷是否有上傳文件 37 if(!empty($_FILES['inexcel']['name'])){ 38 //設置單文件上傳方法 39 $upload = new \Think\Upload();// 實例化上傳類 40 $upload->maxSize = 3145728 ;// 設置附件上傳大小 41 $upload->exts = array('xls','xlsx','csv');// 設置附件上傳類型 42 $upload->rootPath = './Public/upfile/excel/'; // 設置附件上傳根目錄 43 $info = $upload->uploadOne($_FILES['inexcel']); 44 if(!$info) {// 上傳錯誤提示錯誤信息 45 $this->error($upload->getError()); 46 }else{// 上傳成功 獲取上傳文件信息 47 $filename = $upload->rootPath.$info['savepath'].$info['savename']; 48 $ext = $info['ext']; 49 $this->file_import($filename,$ext); 50 } 51 }else{ 52 $this->error('請選擇上傳文件'); 53 } 54 55 } 56 57 /* 58 * 導入數據的方法 file_import($filename,$ext) 59 * @ $filename文件名;$ext文件後綴 60 * 61 * 62 */ 63 function file_import($filename,$exts = 'xlsx'){ 64 //導入phpexcel的類庫->phpexcel沒有命名空間,於是只能import導入 65 import("Org.Util.PHPExcel"); 66 //建立PHPExcel對象,注意,不能少了\ 67 $PHPExcel = new \PHPExcel(); 68 //若是excel文件後綴名爲.xls,導入這個類 69 if($exts == 'xls'){ 70 import("Org.Util.PHPExcel.Reader.Excel5"); 71 $PHPReader=new \PHPExcel_Reader_Excel5(); 72 }else if($exts == 'xlsx' || $exts == 'csv'){ 73 import("Org.Util.PHPExcel.Reader.Excel2007"); 74 $PHPReader=new \PHPExcel_Reader_Excel2007(); 75 } 76 77 //載入文件 78 $PHPExcel=$PHPReader->load($filename); 79 //獲取表中的第一個工做表,若是要獲取第二個,把0改成1,依次類推 80 $currentSheet=$PHPExcel->getSheet(0); 81 //獲取總列數 82 $allColumn=$currentSheet->getHighestColumn(); 83 //獲取總行數 84 $allRow=$currentSheet->getHighestRow(); 85 //循環獲取表中的數據,$currentRow表示當前行,從哪行開始讀取數據,索引值從0開始 86 for($currentRow=1;$currentRow<=$allRow;$currentRow++){ 87 //從哪列開始,A表示第一列 88 for($currentColumn='A';$currentColumn<=$allColumn;$currentColumn++){ 89 //數據座標 90 $address=$currentColumn.$currentRow; 91 //讀取到的數據,保存到數組$arr中 92 $data[$currentRow][$currentColumn]=$currentSheet->getCell($address)->getValue(); 93 } 94 } 95 $this->save_import($data); 96 97 } 98 99 //保存存入的數據 100 function save_import($data){ 101 //var_dump($data); 102 $crm = M('company'); 103 foreach ($data as $k=>$v){ 104 //從下標是2的開始讀纔是真正的數據 1爲第一行的caption 105 //PS:excel表格裏若是缺乏數據,就會在下面的數組裏面產生空數據,從而致使數據庫寫入錯誤。 106 if($k >= 2){ 107 //對每一行的數據進行去空處理 108 if($v['A']){ 109 $zh=$v['A'];//baidu 110 $info[$k-2]['name_zh'] = $zh; 111 }else{ 112 $info[$k-2]['name_zh'] = ''; 113 } 114 115 if($v['B']){ 116 $en=$v['B'];//wangyi 117 $info[$k-2]['name_en'] = $en; 118 }else{ 119 $info[$k-2]['name_en'] = ''; 120 } 121 122 if($v['c']){ 123 $location=$v['c']; 124 $info[$k-2]['location'] = $location; 125 }else{ 126 $info[$k-2]['location'] = ''; 127 } 128 } 129 } 130 //未來這部分的數據可能會較多,爲了保證數據庫數據的完整性,若是開啓了事物機制,能夠考慮採用事物。 131 $result = $crm->addAll($info); 132 if($result){ 133 $this->success('數據插入成功!'); 134 }else{ 135 $this->error('數據插入失敗!'); 136 } 137 138 } 139 140 /** 141 ** @@get_data() 方法 根據 檢索出來$company_list的值進行excel導出 142 ** 數據結構是一個二維數組$company_list 143 **/ 144 public function get_data($company_list = array()){ 145 header("Content-type:text/html;charset=utf-8"); 146 $result = $company_list; 147 $data = array(); 148 foreach($result as $key=>$val){ 149 $data[$key]['id'] = $val['id']; 150 $data[$key]['name_zh'] = $val['name_zh']; 151 $data[$key]['name_en'] = $val['name_en']; 152 $data[$key]['location'] = $val['location']; 153 } 154 //組裝頭部名稱數組 155 foreach($data as $key=>$v){ 156 if($key == 'id'){ 157 $headArr[] = 'id'; 158 } 159 if($key == 'COMPANY_NAME_ZH'){ 160 $headArr[] = 'COMPANY_NAME_ZH'; 161 } 162 if($key == 'COMPANY_NAME_EN'){ 163 $headArr[] = 'COMPANY_NAME_EN'; 164 } 165 if($key == 'LOCATION'){ 166 $headArr[] = 'LOCATION'; 167 } 168 if($key == 'EDIT'){ 169 $headArr[] = 'EDIT'; 170 } 171 } 172 173 $headArr = array('id','COMPANY_NAME_ZH','COMPANY_NAME_EN','LOCATION','EDIT'); 174 $filename = '合做公司名稱'; 175 $this->getExcel($fileName,$headArr,$data); 176 } 177 178 179 private function getExcel($fileName,$headArr,$data){ 180 //導入PHPExcel類庫,由於PHPExcel沒有用命名空間,只能import導入 181 import("Org.Util.PHPExcel"); 182 import("Org.Util.PHPExcel.Writer.Excel5"); 183 import("Org.Util.PHPExcel.IOFactory.php"); 184 185 $date = date("Y_m_d H:i:s",time()); 186 $fileName .= "_{$date}.xls"; 187 188 //建立PHPExcel對象,注意,不能少了\ 189 $objPHPExcel = new \PHPExcel(); 190 $objProps = $objPHPExcel->getProperties(); 191 192 //設置表頭 193 $key = ord("A"); 194 //print_r($headArr);exit; 195 foreach($headArr as $v){ 196 $colum = chr($key); 197 $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v); 198 $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v); 199 $key += 1; 200 } 201 202 $column = 2; 203 $objActSheet = $objPHPExcel->getActiveSheet(); 204 foreach($data as $key => $rows){ //行寫入 205 $span = ord("A"); 206 foreach($rows as $keyName=>$value){// 列寫入 207 $j = chr($span); 208 $objActSheet->setCellValue($j.$column, $value); 209 $span++; 210 } 211 $column++; 212 } 213 214 $fileName = iconv("utf-8", "gb2312", $fileName); 215 //重命名錶 216 //$objPHPExcel->getActiveSheet()->setTitle('test'); 217 //設置活動單指數到第一個表,因此Excel打開這是第一個表 218 $objPHPExcel->setActiveSheetIndex(0); 219 header('Content-Type: application/vnd.ms-excel'); 220 header("Content-Disposition: attachment;filename=\"$fileName\""); 221 header('Cache-Control: max-age=0'); 222 223 $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); 224 $objWriter->save('php://output'); //文件經過瀏覽器下載 225 exit; 226 } 227 228 229 }
4.導出的EXCEL表以下:數據結構