本文實例講述了php 自定義函數實現將數據 以excel 表格形式導出。分享給大家供大家參考,具體如下:
/** * 導出數據為excel表格 * @param * array $data 一個二維數組,結構如同從數據庫查出來的數組 * array $title excel的第一行標題,一個數組,如果為空則沒有標題 * String $filename 下載的文件名 */ function exportexcel($data=array(),$title=array(),$filename='report'){ header("Content-type:application/octet-stream"); header("Accept-Ranges:bytes"); header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:attachment;filename=".$filename.".xls"); header("Pragma: no-cache"); header("Expires: 0"); //導出xls 開始 if (!empty($title)){ foreach ($title as $k => $v) { $title[$k]=iconv("UTF-8", "GB2312",$v); } $title= implode("\t", $title); echo "$title\n"; } if (!empty($data)){ foreach($data as $key=>$val){ foreach ($val as $ck => $cv) { $data[$key][$ck]=mb_convert_encoding($cv,"GB2312","UTF-8"); } $data[$key]=implode("\t", $data[$key]); } echo implode("\n",$data); } }
php內置函數講解
String mb_convert_encoding( $str, $encoding1,$encoding2 )
$str
,要轉換編碼的字符串
$encoding1
,目標編碼,如utf-8,gbk,大小寫均可
$encoding2
,原編碼,如utf-8,gbk,大小寫均可
demo
$title = array("title1","title2","title3"); $data = array("數據1","數據2","數據3"); $fileName = "demo"; exportexcel($data,$title,$fileName);
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《PHP數組(Array)操作技巧大全》、《PHP數據結構與算法教程》、《php程序設計算法總結》、《PHP數學運算技巧總結》、《php正則表達式用法總結》、《php字符串(string)用法總結》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。