使用php 实现生成Excel文件并导出

2023-11-10

在现在的项目里,不管是电商项目还是别的项目,在管理端都会有导出的功能,比方说订单表导出,用户表导出,业绩表导出。这些都需要提前生成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']);
  }

最后就是这样的效果
在这里插入图片描述不懂的可以留言。。。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用php 实现生成Excel文件并导出 的相关文章

随机推荐

  • 95-34-025-Context-AbstractChannelHandlerContext

    文章目录 1 概述 2 继承体系 3 类签名 4 关键字段 5 构造方法 6 ChannelRead事件 6 1 findContextInbound 7 invokeHandler 1 概述 2 继承体系
  • tensorrt转换模型进行了哪些操作

    对于网络layer graph进行的操作 消除输出未使用的层 消除相当于无操作的操作 卷积 偏置和ReLU运算的融合 具有足够相似参数和相同源张量的运算聚合 例如 GoogleNet v5的初始模块中的1x1卷积 inception结构中同
  • DW9718AF.c

    Copyright C 2015 MediaTek Inc This program is free software you can redistribute it and or modify it under the terms of
  • ERP系统总体解决方案 附下载地址

    企业资源计划即 ERP Enterprise Resource Planning 由美国 Gartner Group 公司于1990年提出 企业资源计划是 MRP II 企业制造资源计划 下一代的制造业系统和资源计划软件 除了MRP II
  • 大数据学习框架及指南

    Hadoop生态圈 一 采集 数据从哪里来 主要包括flume等 一 存储 海量的数据怎样有效的存储 主要包括hdfs Kafka 二 计算 海量的数据怎样快速计算 主要包括MapReduce Spark storm等 三 查询 海量数据怎
  • 数据结构与算法笔记2(线性表)

    1 线性表 1 1线性表是一种逻辑关系 见绪论 1 2定义 是具有相同类型的n个元素的有限序列 其中n为表长 n 0时为空表 关键词 相同类型 一般处理的数据元素都是相同类型 比如一个人那么都是人 而不会把人与车放在一起 关键词 有限序列
  • Java泛型知识点整理

    Java泛型知识点整理 Java泛型 泛型提供了编译时类型安全检测机制 该机制允许程序员在编译时检测到非法的类型 泛型的本质是参数化类型 也就是说所操作的数据类型被指定为一个参数 比如我们要写一个排序方法 能够对整型数组 字符串数组甚至其他
  • ConcurrentHashMap为什么是线程安全的?

    1 ConcurrentHashMap的原理和结构 我们都知道Hash表的结构是数组加链表 就是一个数组中 每一个元素都是一个链表 有时候也把会形象的把数组中的每个元素称为一个 桶 在插入元素的时候 首先通过对传入的键 key 进行一个哈希
  • MapReduce的Job提交流程

    编写一个简单的WordCount程序 Mapper import org apache hadoop io LongWritable import org apache hadoop io Text import org apache ha
  • Tip of the Week #49: Argument-Dependent Lookup

    Tip of the Week 49 Argument Dependent Lookup Originally posted as totw 49 on 2013 07 14 whatever disappearing trail of i
  • 深度学习技术在自动驾驶中的应用与挑战

    导读 深度学习技术经过近几年井喷式的发展 在很多领域都得到了广泛的应用 在自动驾驶系统中 深度学习技术也起到了至关重要的作用 同时也面临着非常多的挑战 我们一直在探索 在一个安全 稳定的自动驾驶产品中 深度学习技术应该有着怎样的作用边界 又
  • Unable to load configuration的解决方法

    最近在学Struts2 5 5 因为喜欢用最新的 并且之前没有学习过的经验 就按照一个网上的博客跟着做一个小实例 里面说直接用 Struts2 5 5中自带例子的struts xml文件 结果我就用了 然后写了一个小程序就一直报 Unabl
  • Java中的对象是什么?

    Java是一种面向对象的编程语言 它将世界视为具有属性和行为的对象的集合 Java的面向对象版本非常简单 它是该语言几乎所有内容的基础 因为它对Java非常重要 所以我将对幕后内容进行一些解释 以帮助任何不熟悉Java的人 遗产 通常 所有
  • 奇安信笔试编程题完整解析附代码

    昨天晚上奇安信笔试 两道编程题做的都不好 有紧张的元素 也有自己实力不够硬的问题 总之把两道编程题又做了一遍 思路屡清楚 下次继续努力 其实两道题非常非常简单 如果放在高中数学 基本就是送分题了 但是最近疫情期间 在家都躺退化了 算了 开搞
  • Android性能优化大法——内存优化

    作者 layz4android 内存 是Android应用的生命线 一旦在内存上出现问题 轻者内存泄漏 重者直接crash 因此一个应用保持健壮 内存这块的工作是持久战 而且从写代码这块就需要注意合理性 所以想要了解内存优化如何去做 要先从
  • jqury ajax 提交from conflict,JQuery中使用ajax提交表单遇到的问题

    今天在做维护时 遇到一段JQuery旧代码 看得很纠结 大致结构如下 html代码 javascript代码 mySubmit click function doSubmit 提交 function doSubmit myForm subm
  • 探讨STOS指令

    转载在http hi baidu com darks00n blog item 4c019ec42ad0cdcad00060b1 html 下面是一段win32 console程序 Debug版 的反汇编代码 很程式化的东西 本文不讨论这段
  • Chromium Win10 开发环境搭建

    记录chromium 开发搭建过程 系统 软件环境不同 所遇问题可能不同 但主体关键相似 仅供参考 VS 安装 安装vs2019 the version 10 0 19041 or higher Windows 10 SDK install
  • idea maven项目运行不了,好多包导不了

    其实是idea默认给你选择了自带的maven和仓库 你可以改成你自己的 使用国内镜像就可以了 先简单记录一下 到时再详细写
  • 使用php 实现生成Excel文件并导出

    在现在的项目里 不管是电商项目还是别的项目 在管理端都会有导出的功能 比方说订单表导出 用户表导出 业绩表导出 这些都需要提前生成excel表 然后在导出 实际上是在代码里生成一张excel表 然后通过下载api进行导出的 好了 先给大家讲