PHP实现生成Excel文件并导出的示例详解
作者:于先生吖 发布时间:2023-05-28 13:11:18
标签:PHP,生成,导出,Excel
在现在的项目里,不管是电商项目还是别的项目,在管理端都会有导出的功能,比方说订单表导出,用户表导出,业绩表导出。这些都需要提前生成excel表,然后在导出,实际上是在代码里生成一张excel表,然后通过下载api进行导出的。好了 先给大家讲一下示例
利用php导出excel我们大多会直接生成.xls文件,这种方便快捷。
首先我们先在项目中引入几个类
use \PhpOffice\PhpSpreadsheet\Spreadsheet;
use \PhpOffice\PhpSpreadsheet\IOFactory;
use \PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use PhpOffice\PhpSpreadsheet\Style\Border;
use PhpOffice\PhpSpreadsheet\Style\Alignment;
然后我们在进行封装一个生成并导出excel表的方法,这里我们用订单表做示例
//订单信息导出excel
public function order_outputProjectExcel($info){
$newExcel = new Spreadsheet();//创建一个新的excel文档
$objSheet = $newExcel->getActiveSheet();//获取当前操作sheet的对象
$date = date('Ymd',time());
$name = '订单信息表';
$objSheet->setTitle($name);//设置当前sheet的标题
//样式设置 - 合并和拆分
$objSheet->mergeCells('A1:P1'); //合并单元格
//$sheet -> unmergeCells('C3:G3'); //拆分单元格
$objSheet->setCellValue('A1',$name);
//设置第一栏的中文标题
$objSheet->setCellValue('A2', '编号')
->setCellValue('B2', '商品图片')
->setCellValue('C2', '商品名称')
->setCellValue('D2', '会员编号')
->setCellValue('E2', '直属')
->setCellValue('F2', '非直属')
->setCellValue('G2', '订单号')
->setCellValue('H2', '商品单价')
->setCellValue('I2', '实付金额')
->setCellValue('J2', '商品佣金')
->setCellValue('K2', '会员佣金')
->setCellValue('L2', '直属佣金')
->setCellValue('M2', '非直属佣金')
->setCellValue('N2', '支付时间')
->setCellValue('O2', '支付渠道')
->setCellValue('P2', '订单状态');
//写入数据
$dataCount = count($info);
$k = 2;
if($dataCount == 0){
exit;
}else{
for ($i=0;$i<$dataCount;$i++){
$k = $k + 1;
$order=$i+1;
$objSheet->setCellValue('A' . $k, $info[$i]['id'])
->setCellValue('B' . $k, $info[$i]['goods_image'])
->setCellValue('C' . $k, $info[$i]['goods_name'])
->setCellValue('D' . $k, $info[$i]['user_num'])
->setCellValue('E' . $k, $info[$i]['user_upteam'])
->setCellValue('F' . $k, $info[$i]['user_un_upteam'])
->setCellValue('G' . $k, $info[$i]['order_id'])
->setCellValue('H' . $k, $info[$i]['goods_price'])
->setCellValue('I' . $k, $info[$i]['payment'])
->setCellValue('J' . $k, $info[$i]['goods_yongjin'])
->setCellValue('K' . $k, $info[$i]['user_yongjin'])
->setCellValue('L' . $k, $info[$i]['user_up_yongjin'])
->setCellValue('M' . $k, $info[$i]['user_un_upyongjin'])
->setCellValue('N' . $k, $info[$i]['paymenttime'])
->setCellValue('O' . $k, $info[$i]['pay_way_ch'])
->setCellValue('P' . $k, $info[$i]['status_ch']);
}
}
//设定样式
//所有sheet的表头样式 加粗
$font = [
'font' => [
'bold' => true,
'size' => 14,
],
];
$objSheet->getStyle('A1:P1')->applyFromArray($font);
//样式设置 - 水平、垂直居中
$styleArray = [
'alignment' => [
'horizontal' => Alignment::HORIZONTAL_CENTER,
'vertical' => Alignment::VERTICAL_CENTER
],
];
$objSheet->getStyle('A1:P2')->applyFromArray($styleArray);
//所有sheet的内容样式-加黑色边框
$borders = [
'borders' => [
'outline' => [
'borderStyle' => Border::BORDER_THIN,
'color' => ['argb' => '000000'],
],
'inside' => [
'borderStyle' => Border::BORDER_THIN,
]
],
];
$objSheet->getStyle('A1:P'.$k)->applyFromArray($borders);
//设置宽度
$cell = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P'];
foreach($cell as $k=>$v){
$objSheet->getColumnDimension($v)->setWidth(20);
// $objSheet->getColumnDimension($v)->setAutoSize(true);
}
$this->downloadExcel($newExcel,$name,'Xlsx');
}
//下载
private function downloadExcel($newExcel,$filename,$format)
{
ob_end_clean();
ob_start();
// $format只能为 Xlsx 或 Xls
if ($format == 'Xlsx') {
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
} elseif ($format == 'Xls') {
header('Content-Type: application/vnd.ms-excel');
}
// strtolower($format)
header("Content-Disposition: attachment;filename="
. $filename . '.' . strtolower($format));
header('Cache-Control: max-age=0');
$objWriter = IOFactory::createWriter($newExcel, $format);
$objWriter->save('php://output');
//通过php保存在本地的时候需要用到
// $objWriter->save($dir.'/demo.xlsx');
//以下为需要用到IE时候设置
// If you're serving to IE 9, then the following may be needed
//header('Cache-Control: max-age=1');
// If you're serving to IE over SSL, then the following may be needed
//header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
//header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
//header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
//header('Pragma: public'); // HTTP/1.0
exit;
}
到这一步其实就已经成功了95%了。剩下的5%只需要你调用上面的方法传入正确的参数即可
model('Apimodel')->order_outputProjectExcel($info);
这里的$info是你的订单详情。必须要做时间筛选,如果不做时间筛选的话 数据量一多,你的系统会崩的。
这里的for循环就是你传入的 $info。 如果说你的 $info 是空的 那么导出的excel打开的时候还会出现
for ($i=0;$i<$dataCount;$i++){
$k = $k + 1;
$order=$i+1;
$objSheet->setCellValue('A' . $k, $info[$i]['id'])
->setCellValue('B' . $k, $info[$i]['goods_image'])
->setCellValue('C' . $k, $info[$i]['goods_name'])
->setCellValue('D' . $k, $info[$i]['user_num'])
->setCellValue('E' . $k, $info[$i]['user_upteam'])
->setCellValue('F' . $k, $info[$i]['user_un_upteam'])
->setCellValue('G' . $k, $info[$i]['order_id'])
->setCellValue('H' . $k, $info[$i]['goods_price'])
->setCellValue('I' . $k, $info[$i]['payment'])
->setCellValue('J' . $k, $info[$i]['goods_yongjin'])
->setCellValue('K' . $k, $info[$i]['user_yongjin'])
->setCellValue('L' . $k, $info[$i]['user_up_yongjin'])
->setCellValue('M' . $k, $info[$i]['user_un_upyongjin'])
->setCellValue('N' . $k, $info[$i]['paymenttime'])
->setCellValue('O' . $k, $info[$i]['pay_way_ch'])
->setCellValue('P' . $k, $info[$i]['status_ch']);
}
最后就是这样的效果
来源:https://blog.csdn.net/weixin_47736740/article/details/127802751


猜你喜欢
- 在讲解Configurable之前,我们首先来看一道面试题:a = 1;console.log( window.a ); // 1conso
- 1 引言这段时间在研究美团爬虫,用的是scrapy-redis分布式爬虫框架,奈何scrapy-redis与scrapy框架不同,默认只发送
- 正在看的ORACLE教程是:Oracle Index 的三个问题。索引( Index )是常见的数据库对象,它的设置好坏
- xhtml+css页面制作过程中问题的解决方案,说是解决方案应该有点过了,充其量只不过是给刚刚开始学标准页面制作的朋友们的一些小建议,如果讲
- MySQL之前有一个查询缓存Query Cache,从8.0开始,不再使用这个查询缓存,那么放弃它的原因是什么呢?在这一篇里将为您介绍。My
- 之前画图一直在用matlibplot、pyecharts,最近学习了一个新的可视化库–cufflinks,用了两天我已经深深爱上它了主要是因
- Python正则表达式中的'r'最近遇到一个非常困惑的地方,那就是在使用Python中的正则表达式的时候,正则表达式前面的&
- 一、 软件介绍 DB2MYSQL是一个可以自动将ACCESS数据库文件转化为对应的SQL代码的软件。可广泛应用于ACCESS数据库转换为MY
- 下面这个例子描述的是在Godaddy-Linux托管帐户上使用JSP连接到某个MySQL数据库。 <%@ page
- 问题描述在电脑中重新安装Anaconda3&PyCharm后,运行原来的程序画图时出现了下图界面。不能弹出如下图所示的“figure”窗口。
- 在Python中需要通过正则表达式对字符串进⾏匹配的时候,可以使⽤⼀个python自带的模块,名字为re。正则表达式的大致匹配过程是:1.依
- 相信大家对python-docx这个常用的操作docx文档的库都不陌生,它支持以内联形状(Inline Shape)的形式插入图片,即图片和
- 一个懒加载的树状表格实例实现一个树状表格,需要用到vxe-table这个库,虽然element-ui也能实现,但这个库是专门针对表格做了更多
- 什么是可变/不可变对象不可变对象,该对象所指向的内存中的值不能被改变。当改变某个变量时候,由于其所指的值不能被改变,相当于把原来的值复制一份
- 我认为多选列表具有完美的功能——只需按下Ctrl键,同时点击鼠标从列表中选择多个项目。以下是一个典型的多选列表框:选出你最喜爱的快餐:&nb
- python的百分号输出比较奇怪,代码如下print('%s%%'%(5))#这样就能输出‘5%'来源:https:
- 迭代器什么是迭代迭代是重复反馈过程的活动,其目的通常是为了逼近所需目标或结果。每一次对过程的重复称为一次“迭代&
- 如何生成斐波那契數列斐波那契(Fibonacci)數列是一个非常简单的递归数列,除第一个和第二个数外,任意一个数都可由前两个数相加得到。用计
- 基本操作查看数据库<code>show databases;</code>指定字符集<code>crea
- 这篇文章主要介绍了python manage.py runserver流程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定