刚开始做项目的时候,遇到了这个需求。说实话,对于一个才出来实习的菜鸟,而且还是才接触PHP的菜鸟而言,实在是有心杀敌,无力回天啊。
最简单的方法,就是网上找一个插件,然后一个本来就十几兆的项目,又增加了两兆多的没有用的东西。最主要的事,直接用插件,还学不会。网上的确有一大堆的PHPExcel的插件,以及和插件有关的文章,但是不是这样的错误就是那样的错误,不是这个最主要的代码没有加上去,就是那个描述不清晰,总之就是一大堆的问题。
然后,狗血的出来了,大神帮我解决我上面说的一大堆的问题时候,跟我说,这个不需要用插件,只要简单的几段函数就可以了。泪崩,花了我好半天的时间,就是那么简单的几句函数。但是,函数简单,不见得函数出现就那么简单。
废话不多说,开始扒代码。
首先是项目文件夹(举例WAP),路径: WAP/COMMON/COMMON/function.php(自定义函数放在这里面,可以直接引用)。
/** * 导出数据为excel表格 *@param $data 一个二维数组,结构如同从数据库查出来的数组 *@param $title excel的第一行标题,一个数组,如果为空则没有标题 *@param $filename 下载的文件名 *@examlpe *$stu = M (‘User‘); *$arr = $stu -> select(); *exportexcel($arr,array(‘id‘,‘账户‘,‘密码‘,‘昵称‘),‘文件名!‘); */ function exportexcel($data=array(),$title=array(),$filename=‘主题活动‘){ //var_dump($data);die(); header("Content-type:application/octet-stream"); header("Accept-Ranges:bytes"); header("Content-type:applicationnd.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]=iconv("UTF-8", "GB2312", $cv); } $data[$key]=implode("\t", $data[$key]); } echo implode("\n",$data); } }
接着是控制层的代码了(ActivityUserController.class.php):
/** * 导出数据为excel表格 *@$data为数据 * @$title_arr为文件头 * @file_name 名字 */ public function excel() { $xlsModel = D(‘ActivityUser‘); $data = $xlsModel->getAllUser(); exportexcel($data,array(‘队员ID‘,‘所属队伍‘,‘队员姓名‘,‘联系方式‘,‘身份标识‘),‘主题活动‘); //方法名() 直接引用dunction.php的方法 }
然后是model层(读取相应的数据)(ActivityUserModel.class.php):
public function getAllUser() { $UserInfo=M(‘activity_team_member‘); $where[‘activity_delete‘]=1; // 过滤条件 $list = $UserInfo ->query(‘select ea_activity_team_member.id,ea_activity_team.team_name,user_name,user_tel,case user_identity when 0 then \‘队长\‘ when 1 then \‘组员\‘ end as user_identity from ea_activity_activity,ea_activity_team,ea_activity_team_member WHERE ea_activity_team.id=ea_activity_team_member.team_id and ea_activity_activity.id=ea_activity_team.activity_id‘); return $list; }
接着是html页面的实现:
<span class="fr">[ <a href="{:U(‘ActivityUser/excel‘)}" >导出</a> ]</span>
简单的梳理一下,首先是在common的文件夹里面增加一个function.php文件,这是存在自定义函数的地方。将excel的导出函数放在里面(直接扒上面的代码)。
在控制器层,定义一个导出excel的方法,同时,定义一个读取数据库的Model层的方法。在这里要提的一点是,我将数据的0和1显示不同的数据(去百度case when), 获取到数据库的数据,接着就是使用自定义的函数了(使用方法: 自定义方法())。
接着要做的就是在html页面,做一个<a></a>标签的跳转,跳转到自己定义的控制层的方法。
Thinkphp导出就是这么简单,代码不多,甚至少的可怜。但是,经验的分享更重要。