推薦一個除了用PHPExcel導出表格之外的另外一種比較簡單不需要引入類文件的表格導入方法——header()導出excel表格。
導出表格的步驟封裝成了方法,以便於重復使用,代碼如下:
1 /** 2 * 導出數據為excel表格 3 *@param $data 一個二維數組,結構如同從數據庫查出來的數組 4 *@param $title excel的第一行標題,一個數組,如果為空則沒有標題 5 *@param $filename 下載的文件名 6 *@examlpe10 */ 11 function exportexcel($data=array(),$title=array(),$filename='report'){ 12 ob_end_clean(); 13 ob_start(); 14 header("Content-type:application/octet-stream"); 15 header("Accept-Ranges:bytes"); 16 header("Content-type:application/vnd.ms-excel"); 17 header("Content-Disposition:attachment;filename=".$filename.".xls"); 18 header("Pragma: no-cache"); 19 header("Expires: 0"); 20 //導出xls 開始 21 if (!empty($title)){ 22 foreach ($title as $k => $v) { 23 $title[$k]=iconv("UTF-8", "GB2312",$v); 24 } 25 $title= implode("\t", $title); 26 echo "$title\n"; 27 } 28 if (!empty($data)){ 29 foreach($data as $key=>$val){ 30 foreach ($val as $ck => $cv) { 31 $data[$key][$ck]=iconv("UTF-8", "GB2312", $cv); 32 } 33 $data[$key]=implode("\t", $data[$key]); 34 } 35 echo implode("\n",$data); 36 } 37 }
簡單舉個例子
1 $data =M ('User')-> select(); 2 $title = array('id','賬戶','密碼','昵稱'); 3 exportexcel($data,$title,'用戶表!');
方法中的ob_end_clean()和ob_start()函數主要用來清除緩存和boom頭防止產生亂碼和格式錯誤。需要做導出操作的話,定義一個二維數組,和一個頭部標題數組然后直接調用下載就行了。
本文屬原創內容,為了尊重他人勞動,轉載請注明本文地址: