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.生成的文件虽然可以打开,但是兼容性很差,每次打开,都会报一个警告:


解决这个问题也不难,具体参见:使用PHPExcel实现Excel文件的导入和导出

  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值