PHP生成excel表格檔案並下載
阿新 • • 發佈:2019-01-11
利用php匯出excel我們大多會直接生成.xls檔案,這種方便快捷。
function createtable($list,$filename){ header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:filename=".$filename.".xls"); $strexport="編號\t姓名\t性別\t年齡\r"; foreach ($list as $row){ $strexport.=$row['id']."\t"; $strexport.=$row['username']."\t"; $strexport.=$row['sex']."\t"; $strexport.=$row['age']."\r"; } $strexport=iconv('UTF-8',"GB2312//IGNORE",$strexport); exit($strexport); }
基於這個我們可以將方法封裝一下:
方法呼叫:/** * 建立(匯出)Excel資料表格 * @param array $list 要匯出的陣列格式的資料 * @param string $filename 匯出的Excel表格資料表的檔名 * @param array $header Excel表格的表頭 * @param array $index $list陣列中與Excel表格表頭$header中每個專案對應的欄位的名字(key值) * 比如: $header = array('編號','姓名','性別','年齡'); * $index = array('id','username','sex','age'); * $list = array(array('id'=>1,'username'=>'YQJ','sex'=>'男','age'=>24)); * @return [array] [陣列] */ protected function createtable($list,$filename,$header=array(),$index = array()){ header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:filename=".$filename.".xls"); $teble_header = implode("\t",$header); $strexport = $teble_header."\r"; foreach ($list as $row){ foreach($index as $val){ $strexport.=$row[$val]."\t"; } $strexport.="\r"; } $strexport=iconv('UTF-8',"GB2312//IGNORE",$strexport); exit($strexport); }
$filename = '提現記錄'.date('YmdHis');
$header = array('會員','編號','聯絡電話','開戶名','開戶行','申請金額','手續費','實際金額','申請時間');
$index = array('username','vipnum','mobile','checkname','bank','money','handling_charge','real_money','applytime');
$this->createtable($cash,$filename,$header,$index);
執行就可以得到表格:
這種方式生成Excel檔案,生成速度很快,但是有缺點是:
1.單純的生成Excel檔案,生成的檔案沒有樣式,單元格屬性(填充色,寬度,高度,邊框顏色...)不能自定義;
2.生成的檔案雖然可以開啟,但是相容性很差,每次開啟,都會報一個警告: