第一步:先到官网(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. Java-JDK-windows和linux版-百度云下载

    链接: https://pan.baidu.com/s/15vjk4PNzuItd5vHJ6deq3Q 关注以下公众号,回复[9757],获取提取码 linux:jdk-8u221-linux-x64 ...

  2. Nginx-rtmp之配置项的管理

    1. 概述 Nginx-rtmp 对 rtmp{...} 内的配置项划分了几个级别: 直接隶属于 rtmp{} 块内的配置项称为 main 配置项. 直接隶属于 server{} 块内的配置项称为 s ...

  3. android data binding jetpack II 动态数据更新

    android data binding jetpack VIII BindingConversion android data binding jetpack VII @BindingAdapter ...

  4. 代码实现:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称

    package com.loaderman.test; import java.io.File; import java.io.FilenameFilter; public class Test { ...

  5. 20 Django REST Framework 更改PUT/PATCH/DELETE的传参字段,默认为pk

    01-lookup_field 默认为 lookup_field='pk' 更改后的效果:

  6. 六十一:Flask.Session之flask操作session

    1.设置session:使用flask.session就可以操作字典,操作方式和操作字典一样:session['key']=value2.获取session,和获取字典的值一样:session['ke ...

  7. 数据库高级数据库学习--上机练习5(Transact-SQL)

    上机练习5 启动SQL Server 2008中的 SQL Server Management Studio,恢复数据库ClassDB: 采用Transact-SQL程序设计完成以下练习: . 求1到 ...

  8. 【JVM学习笔记】打破双亲委托机制的例子

    Tomcat也有自己的类加载器,比如Servlet,这些类加载器就改变了双亲委托模型的默认机制 (该主题有待深入)

  9. oslo_db.sqlalchemy.engines连库

    _ mysql -uroot -pc1234 oslo_db.sqlalchemy.engines root@devstack2019:/etc/keystone# more keystone.con ...

  10. list 属性字段直接转成字符串数组

    List<Car> cars = //whatever; string concat = String.Join(",", cars.Select(c => c. ...