第一步:先到官网(https://github.com/PHPOffice/PHPExcel)下载PHPExcel

第二步:放到第三方库

第三步:

 /**
* 封装:信息导出
* @param $day
* @param string $tableName
* @throws PHPExcel_Exception
* @throws PHPExcel_Reader_Exception
*/
public function Db2Eexcel($data, $tableName = "用户支付数据"){ vendor("PHPExcel.PHPExcel"); // 1. 实例化工作簿
$excel = new \PHPExcel(); // 2. 得到前当活动工作表
$sheet = $excel->getActiveSheet(); // 3. Excel表格式,这里简略写了14列
$letter = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q']; // 3.1 表头数组
$tableheader = ['ID','订单创建时间','订单处理时间','支付平台单号','商户订单号','支付类型','支付金额','实际支付金额','银行卡','商品名称','支付状态','游戏支付状态','账号','服务器ID','渠道','子渠道','游戏ID']; // 3.2 填充表头信息, 并设置样式
for($i = ;$i < count($tableheader);$i++) {
$sheet->getCell("$letter[$i]1")->setValue("$tableheader[$i]");
$sheet->getStyle("$letter[$i]1")->getAlignment()->setHorizontal('center'); // 统一设置水平居中
$sheet->getStyle("$letter[$i]1")->getAlignment()->setVertical('center'); // 统一设置垂直居中
$sheet->getStyle("$letter[$i]1")->getFont()->getColor()->setRGB('b5211a'); // 统一设置单元格字段颜色
$sheet->getStyle("$letter[$i]1")->getFont()->setSize(); // 统一设置字体大小
$sheet->getStyle("$letter[$i]")->getFont()->setSize();
$sheet->getStyle("$letter[$i]1")->getFont()->setBold(true); // 统一设置加粗
$sheet->getColumnDimension("$letter[$i]")->setWidth(); // 统一设置宽度
} // 3.3 样式:第1行的高度
$sheet->getRowDimension('')->setRowHeight(); // 3.4 样式:列的宽度
$sheet->getColumnDimension('A')->setWidth();
$sheet->getColumnDimension('B')->setWidth();
$sheet->getColumnDimension('C')->setWidth();
$sheet->getColumnDimension('D')->setWidth();
$sheet->getColumnDimension('E')->setWidth();
$sheet->getColumnDimension('F')->setWidth();
$sheet->getColumnDimension('G')->setWidth();
$sheet->getColumnDimension('H')->setWidth();
$sheet->getColumnDimension('I')->setWidth();
$sheet->getColumnDimension('J')->setWidth();
$sheet->getColumnDimension('K')->setWidth();
$sheet->getColumnDimension('L')->setWidth();
$sheet->getColumnDimension('M')->setWidth();
$sheet->getColumnDimension('N')->setWidth();
$sheet->getColumnDimension('O')->setWidth();
$sheet->getColumnDimension('P')->setWidth();
$sheet->getColumnDimension('Q')->setWidth(); // 4. 填充表格信息
for ($i = , $k = ; $i <= count($data)+; $i++, $k++) {
$j = ; // 格式化:时间
if(!empty($data[$k]['ftime'])){
$data[$k]['ftime'] = date('Y/m/d H:i:s', $data[$k]['ftime']);
}
if(!empty($data[$k]['ptime'])){
$data[$k]['ptime'] = date('Y/m/d H:i:s', $data[$k]['ptime']);
} // 格式化:支付类型 1:支付宝 2:微信
if(!empty($data[$k]['paytype'])){
if($data[$k]['paytype'] == ){
$data[$k]['paytype'] = "支付宝";
}
if($data[$k]['paytype'] == ){
$data[$k]['paytype'] = "微信";
}
} //格式化:支付状态1成功0失败
if(isset($data[$k]['paystatus']))
{
$data[$k]['paystatus'] = $data[$k]['paystatus'] == ? "成功" : "失败";
}
if(isset($data[$k]['gamepaystatus']))
{
$data[$k]['gamepaystatus'] = $data[$k]['gamepaystatus'] == ? "成功" : "失败";
} foreach ($data[$i - ] as $key=>$value) {
$sheet->getCell("$letter[$j]$i")->setValue("$value");
$sheet->getStyle("$letter[$j]$i")->getAlignment()->setHorizontal('center');
$j++;
}
} // 6. 保存文件:输出到浏览器
$writer = \PHPExcel_IOFactory::createWriter($excel,'Excel2007');
self::browser_export('Excel2007', $tableName.'.xlsx'); //输出到浏览器
$writer->save("php://output");
} /**
* 输出到浏览器
* @param $type
* @param $filename
*/
function browser_export($type,$filename){
if($type=="Excel5"){
header('Content-Type: application/vnd.ms-excel');//告诉浏览器将要输出excel03文件
}else{
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;');//告诉浏览器数据excel07文件
}
ob_end_clean();//清除缓存区,避免乱码
header('Content-Disposition: attachment;filename="'.$filename.'"'); //告诉浏览器将输出文件的名称
header('Cache-Control: max-age=0'); //禁止缓存
}

PHP 下载mysql数据到PHPExcel表格的更多相关文章

  1. PHPExcel使用-使用PHPExcel导出文件-导出MySQL数据

    现在数据库里面有一组数据,我们将它按照不同的难度进行分sheet. 首先我们需要写一个mysql的配置文件- db.config.php(utf-8编码) : <?php $dbconfig= ...

  2. linux下导入、导出mysql数据库命令 下载文件到本地

    一.下载到本地 yum install lrzsz sz filename  下载 rz filename  上传   linux下导入.导出mysql数据库命令 一.导出数据库用mysqldump命 ...

  3. java 导mysql数据为表格给浏览器接收

    jar 包准备 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</a ...

  4. php动态导出数据成Excel表格

    一.封装 Excel 导出类 include/components/ExecExcel.php <?php /*** * @Excel 导入导出类. */ class ExecExcel { / ...

  5. Echart显示后端mysql数据

    一.基本思想 1.将数据存储在mysql数据库中 2.后端链接数据库,将数据库中的数据保存为json格式 3.将json格式数据使用ajax传到前端JSP页面中的Echarts 二.实现的关键点 1. ...

  6. MySQL 数据操作与查询笔记 • 【第1章 MySQL数据库基础】

    全部章节   >>>> 本章目录 1.1 数据库简介 1.1.1 数据和数据库定义 1.1.2 数据库发展阶段 1.1.3 数据库系统组成 1.1.4 关系型数据库 1.2 M ...

  7. Phantomjs+Nodejs+Mysql数据抓取(2.抓取图片)

    概要 这篇博客是在上一篇博客Phantomjs+Nodejs+Mysql数据抓取(1.抓取数据) http://blog.csdn.net/jokerkon/article/details/50868 ...

  8. 使用Solr索引MySQL数据

    环境搭建 1.到apache下载solr,地址:http://mirrors.hust.edu.cn/apache/lucene/solr/ 2.解压到某个目录 3.cd into D:\Solr\s ...

  9. ElasticSearch5+logstash的logstash-input-jdbc实现mysql数据同步

    在实现的路上遇到了各种坑,再次验证官方文档只能产考不能全信! ElasticSearch安装就不说了上一篇有说! 安装logstash 官方:https://www.elastic.co/guide/ ...

随机推荐

  1. 修改mp3图片和信息——BesMp3Editor

    导读 BesMp3Editor, 是一款小巧的 MP3 编辑工具,可以修改.添加 MP3 上的图片.歌曲名.歌手.专辑信息. 最近想给 BesLyric-for-X 添加一个功能,为下载下来的歌曲添加 ...

  2. Appium+Robotframework实现iOS应用的自动化测试

    Appium+Robotframework实现iOS应用的自动化测试 连接地址: 地址:https://blog.csdn.net/wd168/article/month/2016/06 1.http ...

  3. 更换django自带的下载链接

    class Case(models.Model): file_type = MyFileField(verbose_name='file_obj', max_length=256, blank=Tru ...

  4. Python轻量级开发工具Genay使用

    Genay是一个轻量级的免费,开放源代码的开发工具,支持很多的文件类型,并且支持很多的插件,启动快速.安装包只有十几兆,相关的插件也不大,相比pycharm专业版需要收费,并且社区版的安装包大小有两百 ...

  5. ThinkPhp sql语句执行方法

    ThinkPHP内置的ORM和ActiveRecord模式实现了方便的数据存取操作,而且新版增加的连贯操作功能更是让这个数据操作更加清晰,但是ThinkPHP仍然保留了原生的SQL查询和执行操作支持, ...

  6. 卸载阿里云盾(安骑士)监控&屏蔽云盾IP

    卸载阿里云盾监控 wget http://update.aegis.aliyun.com/download/uninstall.sh chmod +x uninstall.sh ./uninstall ...

  7. 前端性能之Chrome的Waterfall

    浏览器根据HTML中外连资源出现的顺序,依次放入队列(队列),然后根据优先级确定向服务器获取资源的顺序.同优先级的资源根据HTML中出现的先后顺序来向服务器获取资源. 瀑布中各项内容的含义: 排队: ...

  8. java 抽取 word,pdf 的四种武器

    转自:https://www.ibm.com/developerworks/cn/java/l-java-tips/     感谢作者发布的文章 用 jacob 其实 jacob 是一个 bridag ...

  9. 阶段3 3.SpringMVC·_02.参数绑定及自定义类型转换_5 自定义类型转换器演示异常

    后端自动进行类型的转换.前端输入的年龄都是字符串的形式传递到后端. user的实体类  加一个Date日期类型格式的字段.生成get和set还有toString的方法 重新部署程序 日期用横线的方式 ...

  10. iOS证书详解--转载

    一.成员介绍1.    Certification(证书)证书是对电脑开发资格的认证,每个开发者帐号有一套,分为两种:1)    Developer Certification(开发证书)安装在电脑上 ...