PHPEXCEL 导出excel

在这里插入图片描述

       $styleArray = [
            'alignment' => [
                'horizontal' => Alignment::HORIZONTAL_CENTER,
                'vertical' => Alignment::VERTICAL_CENTER
            ],
        ];
        $border_style = [
            'borders' => [
                'allborders' => [
                    'style' =>  \PHPExcel_Style_Border::BORDER_THIN ,//细边框
                ]
            ]
        ];

        $begin_date = $request->begin_date;
        $end_date = $request->end_date;
        $search = $request->search_word;
        $arr_com = [];
        if (isset($request->com_val)){
            $arr_com = explode(',',$request->com_val);
        }
        $arr_fact = [];
        if (isset($request->fact_val)){
            $arr_fact = explode(',',$request->fact_val);
        }
        $res = $this->getData($begin_date,$end_date,$search,$arr_com,$arr_fact,0,0);
        $data = $res['data'];
        if(count($data)>0){
            ob_end_clean();
            ob_start();
            // 最后导出
            $year = date('Y',strtotime($begin_date));
            $week = intval(date('W',strtotime($begin_date)));
            $filename = $year.'年'.$week.'周出货表';

            $objPHPExcel = new \PHPExcel();
            $objPHPExcel->getActiveSheet()->setTitle($filename);
            $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(10);
            $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(30);
            //行高
            $objPHPExcel->getActiveSheet()->getRowDimension('1')->setRowHeight(40);
            $objPHPExcel->getActiveSheet()->getRowDimension('2')->setRowHeight(20);
            //第一行
            $objPHPExcel->getActiveSheet()->getCell("A1")->setValue($filename);
            $objPHPExcel->getActiveSheet()->mergeCells('A1:I1');
            //第二行
            $objPHPExcel->getActiveSheet()->getCell("A2")->setValue('出货日期');
            $richTextObj = new \PHPExcel_RichText(); //每一行都需要重新New一个richText
            $setStyleObj = $richTextObj->createTextRun("国别(海运/");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("空运");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FFFF0000")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("/");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("陆运");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF00FF00")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("/");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("铁路");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF0000FF")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("/");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun("海空");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FFFF00FF")); //设置颜色
            $setStyleObj = $richTextObj->createTextRun(")");
            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
            $objPHPExcel->getActiveSheet()->getCell("E2")->setValue($richTextObj);

            //数据写进Excel,并对关键字高亮处理
            foreach ($data as $key =>$value){
                $excelRow = ($key + 3); //excel第几行
                $objPHPExcel->getActiveSheet()->getCell('D'.$excelRow)->setValue($value['tod_date']);

                //国别 运输方式处理
                $richTextObjNation = new \PHPExcel_RichText(); //每一行都需要重新New一个richText 拼接 运输方式 突击拔高
                $count_nation = count($value['nations']);
                foreach ($value['nations'] as $k_nation => $v_nation){
                    //国别 运输方式:  0海运,1空运,2陆运,3铁路,4海空
                    if($v_nation['flag'] == 0){
                        $setStyleObj = $richTextObjNation->createTextRun($v_nation['name']);
                        $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        if($k_nation != $count_nation - 1){
                            $setStyleObj = $richTextObjNation->createTextRun("、");
                            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        }
                    }
                    if($v_nation['flag'] == 1){
                        $setStyleObj = $richTextObjNation->createTextRun($v_nation['name']);
                        $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FFFF0000")); //设置颜色
                        if($k_nation != $count_nation - 1){
                            $setStyleObj = $richTextObjNation->createTextRun("、");
                            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        }
                    }
                    if($v_nation['flag'] == 2){
                        $setStyleObj = $richTextObjNation->createTextRun($v_nation['name']);
                        $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF00FF00")); //设置颜色
                        if($k_nation != $count_nation - 1){
                            $setStyleObj = $richTextObjNation->createTextRun("、");
                            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        }
                    }
                    if($v_nation['flag'] == 3){
                        $setStyleObj = $richTextObjNation->createTextRun($v_nation['name']);
                        $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF0000FF")); //设置颜色
                        if($k_nation != $count_nation - 1){
                            $setStyleObj = $richTextObjNation->createTextRun("、");
                            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        }
                    }
                    if($v_nation['flag'] == 4){
                        $setStyleObj = $richTextObjNation->createTextRun($v_nation['name']);
                        $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FFFF00FF")); //设置颜色
                        if($k_nation != $count_nation - 1){
                            $setStyleObj = $richTextObjNation->createTextRun("、");
                            $setStyleObj->getFont()->setColor(new \PHPExcel_Style_Color("FF000000")); //设置颜色
                        }
                    }
                }
                $objPHPExcel->getActiveSheet()->getCell('E'.$excelRow)->setValue($richTextObjNation);
                $objPHPExcel->getActiveSheet()->getRowDimension($excelRow)->setRowHeight(20);
                $objPHPExcel->getActiveSheet()->getStyle('E'.$excelRow)->getAlignment()->setWrapText(true);
            }
            //垂直居中
            $objPHPExcel->getActiveSheet()->getStyle('A1:I2')->applyFromArray($styleArray);
            //细边框
            $objPHPExcel->getActiveSheet()->getStyle('A2:I'.$excelRow)->applyFromArray($border_style);
            //字体
            $objPHPExcel->getActiveSheet()->getStyle('A1:I1')->getFont()->setBold(true)->setName('黑体')->setSize(16);
            $objPHPExcel->getActiveSheet()->getStyle('A2:I2')->getFont()->setBold(true)->setName('宋体')->setSize(12);
            // 导出excel
            ob_end_clean();
            header('Content-Type: application/vnd.ms-excel');
            header('Content-Disposition: attachment;filename="' . $filename . '.xls');
            header('Cache-Control: max-age=0');
            header('Content-Type: text/html; charset=utf-8');
            //$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
            $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, "Excel2007");
            $objWriter->save('php://output');
            exit;
        }
        else{
            return response()->json(['code' => 1,'msg' => '没有数据'] );
        }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/94457.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

损失函数介绍

用softmax,就可以将一个输出值转换到概率取值的一个范围。 交叉熵损失CrossEntropyLoss 第一个参数weight, 各类别的loss设置权值, 如果类别不均衡的时候这个参数很有必要了,加了之后损失函数变成这样: 第二个参数ign…

Leetcode 191.位1的个数

编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 1 的个数(也被称为汉明重量)。 提示: 请注意,在某些语言(如 Java)中…

微服务之Nacos

1 版本说明 官网地址: https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E 1.1 2021.x 分支 适配 SpringBoot 2.4, Spring Cloud 2021.x 版本及以上的Spring Cloud Alibaba 版本如下表(最新版本用*标记&am…

036 - timezone

timestamp随着mysql的time_zone变化而变化,但是datetime不会; -- 查询mysql的变量: show variables;-- 模糊查询变量中带有time_zone的变量: show variables like %time_zone%; -- 创建表 create table test_time_zone (a dateti…

小蜗语音工具1.9、文本,小说,字幕生成语音、多角色对话,语音识别、读取音频字幕

小蜗语音免费工具 一、文本转字幕文本内容和TXT文件 二、文本转语音1、文本内容生成语音2、字幕生成语音3、多角色对话4、选择文件5、批量处理 三、语音识别、音频MP31、语音识别2、下载模型下载地址 一、文本转字幕 可以把正本小说,生成字幕文件。不限制文件的大小…

用NeRFMeshing精确提取NeRF网络中的3D网格

准确的 3D 场景和对象重建对于机器人、摄影测量和 AR/VR 等各种应用至关重要。 NeRF 在合成新颖视图方面取得了成功,但在准确表示底层几何方面存在不足。 推荐:用 NSDT编辑器 快速搭建可编程3D场景 我们已经看到了最新的进展,例如 NVIDIA 的…

汽车制造行业,配电柜如何实施监控?

工业领域的生产过程依赖于高效、稳定的电力供应,而配电柜作为电力分配和控制的关键组件,其监控显得尤为重要。 配电柜监控通过实时监测、数据收集和远程控制,为工业企业提供了一种有效管理电能的手段,从而确保生产的连续性、安全性…

针对论坛系统进行功能测试和性能测试

项目链接:飞鸽论坛 目录 一. 项目背景 二. 项目功能 三. 功能测试 注册: 登录: 更改用户信息: 发布帖子: 更新帖子信息: 点赞: 评论: 发送私信: 测试报告 四. 性能测试 Virtual User Generator Controller Analysis 测试报告: 一. 项目背景 该论坛系统采用前…

二级MySQL(二)——编程语言,函数

SQL语言又称为【结构化查询语言】 请使用FLOOR(x)函数求小于或等于5.6的最大整数 请使用TRUNCATE(x,y)函数将数字1.98752895保留到小数点后4位 请使用UPPER()函数将字符串‘welcome’转化为大写…

Oracle创建控制列表ACL(Access Control List)

Oracle创建控制列表ACL(Access Control List) Oracle ACL简介一、先登陆163邮箱设置开启SMTP。二、Oracle ACL控制列表处理(一)创建ACL(create_acl)(二)添加ACL权限(add_…

研磨设计模式day11代理模式

目录 场景 代码实现 ​编辑 解析 定义 代理模式调用示意图 代理模式的特点 本质 ​编辑何时选用 场景 我有一个订单类,包含订单数、用户名和商品名,有一个订单接口包含了对订单类的getter和setter 现在有一个需求,a创建的订单只…

css元素定位:通过元素的标签或者元素的id、class属性定位,还不明白的伙计,看这个就行了!

前言 大部分人在使用selenium定位元素时,用的是xpath元素定位方式,因为xpath元素定位方式基本能解决定位的需求。xpath元素定位方式更直观,更好理解一些。 css元素定位方式往往被忽略掉了,其实css元素定位方式也有它的价值&…

使用Angular和MongoDB来构建具有登录功能的博客应用程序

Angular 是一个一站式框架,用于使用相同的可重用代码创建移动和 Web 应用程序。使用 Angular,您可以将整个应用程序划分为可重用的组件,从而更轻松地维护和重用代码。 在本教程系列中,您将学习如何开始使用 Angular 和 MongoDB 作…

kafka复习:(22)一个分区只能被消费者组中的一个消费者消费吗?

默认情况下,一个分区只能被消费者组中的一个消费者消费。但可以自定义PartitionAssignor来打破这个限制。 一、自定义PartitionAssignor. package com.cisdi.dsp.modules.metaAnalysis.rest.kafka2023;import org.apache.kafka.clients.consumer.internals.Abstrac…

Kubernetes(K8s 1.28.x)部署---超详细

目录 一、基础环境配置(所有主机均要配置) 1、配置IP地址和主机名、hosts解析 2、关闭防火墙、禁用SELinux 3、安装常用软件 4、配置时间同步 5、禁用Swap分区 6、修改linux的内核参数 7、配置ipvs功能 二、容器环境操作 1、定制软件源 2、安…

JavaScript—对象与构造方法

目录 json对象(字面值) js中对象是什么? 如何使用? 关联数组 js对象和C#对象有什么区别? 构造函数 什么是构造方法? 如何使用构造方法? 如何添加成员? 对象的动态成员 正则…

ubuntu上安装nginx

这篇文章主要介绍怎么在ubuntu上安装nginx服务器,并配置简单的反向代理功能。 第一步:准备好一台ubuntu操作系统的虚拟机 注意:如果你还没有安装好ubuntu,个人推荐阅读以下文章完成unbutu安装,vm的版本不用刻意安装文…

ORB-SLAM2算法10之图像关键帧KeyFrame

文章目录 0 引言1 KeyFrame类1.1 构造函数1.2 成员函数1.3 关键帧之间共视图1.3.1 AddConnection1.3.2 UpdateBestCovisibles1.3.3 UpdateConnections1.3.4 EraseConnection1.3.5 SetBadFlag 1.4 地图点1.5 生成树 2 KeyFrame用途 0 引言 ORB-SLAM2算法7详细了解了System主类和…

算法leetcode|74. 搜索二维矩阵(rust重拳出击)

文章目录 74. 搜索二维矩阵:样例 1:样例 2:提示: 分析:题解:rust:go:c:python:java: 74. 搜索二维矩阵: 给你一个满足下述两条属性的…

Spring Cloud Nacos 和 Eureka区别,包含实战代码

目录 一、Spring Cloud Eureka详解二、Spring Cloud Nacos详解三、Spring Cloud Nacos和Eureka区别 Spring Cloud Nacos 和 Spring Cloud Eureka 都是 Spring Cloud 微服务框架中的服务注册和发现组件,用于帮助开发者轻松地构建和管理微服务应用。它们之间的主要区别…