【php】PHP生成excel表格文件並下載


利用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.生成的文件雖然可以打開,但是兼容性很差,每次打開,都會報一個警告:

 

 
        

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM