第一步:先到官网(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. 用python绘制趋势图

    import matplotlib.pyplot as plt #plt用于显示图片 import matplotlib.image as mping #mping用于读取图片 import date ...

  2. 学习笔记01:《开放平台产品成长之路-POP》

    当看到一些比较好的书籍和视频内容时,希望自己可以总价归纳下来,一方面是好的东西希望可以分享给大家,另一方面希望自己能很好的吸收并转化成掌握的知识,所以有了这个系列的学习笔记,共勉,今天的你比昨天更博学 ...

  3. 链表反转 C++

    ListNode* reverse1(ListNode* pHead) { if(pHead == NULL) return NULL; ListNode * p1 = NULL; ListNode ...

  4. centos的KVM初级安装

    什么是KVM虚拟化技术?KVM(Kernel-based Virtual Machine),主流虚拟化技术之一,集成与Linux2.6之后版本中,通过linux内核提供任务调度及管理.kvm,在实现虚 ...

  5. exe4J打包jar文件成exe可执行文件

    exe4j_6.0下载(x86\x64\注册机):        https://pan.baidu.com/s/1oFzif5ZVswbgbBkKHc8HFQ 打包步骤: 再次偷一下懒,使用别人的内 ...

  6. IntelliJ IDEA 2019 注册码 (激活码) 有效期至2100年

    IntelliJ IDEA 2019 注册码 (激活码) 有效期至2100年 本人使用的IDEA是最新版:IntelliJ IDEA 2018.3.3 x64 (IntelliJ IDEA官网下载地址 ...

  7. dependencies与devDependencies之间的区别

    dependencies:依赖 dev:develop(开发)的简写 1.--save-dev 和--save 的区别: 我们在使用npm install 安装模块或插件的时候,有两种命令把它们写入到 ...

  8. Qt qss 动态属性-不同条件不同显示

    一. 1.为了用户界面外观的动态变化,属性选择器可以与动态属性组合使用. 2.当一个属性值变化时,所引用的样式不会自动更新.相反地,必须手动触发更新才会生效.unpolish()用于清理之前的样式,而 ...

  9. 使用现代 C++ 技术增强多核优化

    在本文中,读者将了解如何使用现代 C++ 技术跨内核并行处理数据.通过研究示例代码,下载应用和学习技术,开发人员将更好地了解英特尔® 架构和多核技术.通过学习如何处理潜在的性能瓶颈和并发性问题,可以使 ...

  10. WIN10远程协助无法控制的解决方法

    这个问题比较常见小编整理的解决方法如下: 方法一:用QQ远程协助对方电脑,需要QQ告诉对方右键单击计算机(这台电脑)点管理打开计算机管理界面选择本地用户和组,再选择用户,右侧会出现所有的本地用户,包括 ...