下面小編就為大家帶來一篇使用PHPExcel實作資料批次匯出為excel表格的方法(必看)。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧
首先需要下載PHPExecel類別文件,幫助文件可以參考PHPExcel中文幫助手冊|PHPExcel使用方法。
下面直接上例子,是我自己寫的一個簡單的批量導出資料為excel的例子
前台頁面 比較簡單,就是一個超鏈接,跳到處理頁面,超鏈接也可以跟一些參數(看需求)!
<a href="./Process1.php" rel="external nofollow" >导出excel表格</a>
後台Process.php頁面
/** * 批量导出数据 * @param $arr 从数据库查询出来,即要导出的数据 * $name excel表歌名 */ function expExcel($arr,$name){ require_once 'PHPExcel.php'; //实例化 $objPHPExcel = new PHPExcel(); /*右键属性所显示的信息*/ $objPHPExcel->getProperties()->setCreator("zxf") //作者 ->setLastModifiedBy("zxf") //最后一次保存者 ->setTitle('数据EXCEL导出') //标题 ->setSubject('数据EXCEL导出') //主题 ->setDescription('导出数据') //描述 ->setKeywords("excel") //标记 ->setCategory("result file"); //类别 //设置当前的表格 $objPHPExcel->setActiveSheetIndex(0); // 设置表格第一行显示内容 $objPHPExcel->getActiveSheet() ->setCellValue('A1', '业主姓名') ->setCellValue('B1', '密码') ->setCellValue('C1', '手机号码') ->setCellValue('D1', '地址') //设置第一行为红色字体 ->getStyle('A1:D1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_RED); $key = 1; /*以下就是对处理Excel里的数据,横着取数据*/ foreach($arr as $v){ //设置循环从第二行开始 $key++; $objPHPExcel->getActiveSheet() //Excel的第A列,name是你查出数组的键值字段,下面以此类推 ->setCellValue('A'.$key, $v['name']) ->setCellValue('B'.$key, $v['pwd']) ->setCellValue('C'.$key, $v['phone']) ->setCellValue('D'.$key, $v['address']); } //设置当前的表格 $objPHPExcel->setActiveSheetIndex(0); ob_end_clean(); //清除缓冲区,避免乱码 header('Content-Type: application/vnd.ms-excel'); //文件类型 header('Content-Disposition: attachment;filename="'.$name.'.xls"'); //文件名 header('Cache-Control: max-age=0'); header('Content-Type: text/html; charset=utf-8'); //编码 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); //excel 2003 $objWriter->save('php://output'); exit; } /***********调用**********************/ header("Content-type:text/html;charset=utf-8"); //链接数据库 $link = @mysql_connect('localhost','root','') or die('连接数据库失败'); mysql_select_db('test',$link); mysql_query('set names utf8'); //先获取数据 $sql = "select * from house"; $res = mysql_query($sql); $arr = array(); //把$res=>$arr,把结果集内容转移到一个数组中 while ($row = mysql_fetch_assoc($res)){ $arr[] = $row; } //excel表格名 $name = "用户表"; //调用 expExcel($arr,$name)
使用PHPExcel匯出資料至此完畢,對於使用PHPExcel匯入到資料庫可以參考使用PHPExcel實現資料批次上傳到資料庫
以上是使用PHPExcel實作資料批次匯出為excel表格的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!