推荐一个除了用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头防止产生乱码和格式错误。需要做导出操作的话,定义一个二维数组,和一个头部标题数组然后直接调用下载就行了。
原创:http://www.cnblogs.com/luokakale/p/8352517.html
Shop7z网上购物系统支持电脑版+手机版+支付宝及微信支付,支持QQ和微信一键登陆,系统集众家之所长,大气超美观页面+手机版+商品组合套餐+限时抢购秒杀+图片批量上传+淘宝数据包导入+弹出式分类菜单+不同规格不同价格+新订单邮件通知+销售报表打印与Excel输出+物流跟踪打印查询+会员积分及优惠券+邮件群发+图片在线管理+销售统计报表+五种价格体系+礼品礼券+微信公众号支付+扫码支付等等等。
立即学习“PHP免费学习笔记(深入)”;
相关推荐:










