PhpSpreadsheet表格导出

个人笔记记录

使用PhpSpreadsheet 导出excel。

多重表头生成excel 表

    //读取数据库
    public function demo1()
    {
        // 连接spc数据库
        $config = Config::get('databaseedc');
        $db = Db::connect($config);

        $data =$db->name("xxxx")
            ->alias('a')
            ->field('main_header, sub_header,fvi_value')
            ->join('')
            ->where('')
            ->select();

          $this->exportDataToExcel($data);
    }
    // 将数据转换为Excel格式并保存
    function exportDataToExcel($data) {

        //从初始化表格
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();

        // 处理数据和表头
        $mainHeaders = $this->getMainHeaders($data);

        //提取次级表头和数据
        $subHeadersAndData = $this->getSubHeadersAndData($data);

        // 设置表头
        $this->setHeaders($sheet, $mainHeaders, $subHeadersAndData);

        //设置Excel的数据
        $currentRow = 2;//初始行
        $col=1; //初始列

        //循环主表头
        foreach ($mainHeaders as $subData){

            //循环次级表头和数据
            foreach ($subHeadersAndData as $subHeaderKey => $subHeaderData) {
                // 获取主表头部分
                $mainHeaderPart = explode('_', $subHeaderKey)[0];

                //查找于当前表头一致的数据
                if($mainHeaderPart==$subData){
                     echo("<pre>");
                     print_r($subHeaderKey);
                    //设置子标题:
                    $sheet->setCellValueByColumnAndRow($col, $currentRow, $subHeaderData['sub_header']);
                    //设置子标题相关的数据
                    foreach ($subHeaderData['data'] as $index => $value) {
                        $sheet->setCellValueByColumnAndRow($col, $currentRow + $index + 1, $value);
                    }
                    $col++;
                }

            }
        }
 // 保存文件
        $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $filename = './excel/' . date('YmdHis') . '.xlsx'; // 使用动态文件名避免冲突
        $result = $writer->save($filename);
    }
    //从数据中提取主表头
    public function getMainHeaders($data) {
        $mainHeaders = [];
        foreach ($data as $item) {
            //检查 main_header 是否已在 $mainHeaders 中
            if (!in_array($item['main_header'], $mainHeaders)) {
                //不存在,加入数组
                $mainHeaders[] = $item['main_header'];
            }
        }
        return $mainHeaders;
    }
    //从数据中提取次级表头和数据
    function getSubHeadersAndData($data) {
        $subHeaders = [];//存储处理后的子标题及其相关数据
        $rowData = [];
        foreach ($data as $item) {
            $subHeaderKey = $item['main_header'] . '_' . $item['sub_header'];
            //检查 $subHeaders 数组中是否已经存在该子标题键
            if (!isset($subHeaders[$subHeaderKey])) {
                $subHeaders[$subHeaderKey] = [
                    'sub_header' => $item['sub_header'],
                    'data' => []
                ];
            }
            //$item 中的 'fvi_value' 添加到与该子标题关联的 'data' 数组中。
            $subHeaders[$subHeaderKey]['data'][] = $item['fvi_value'];
        }
        return $subHeaders;
    }
    //设置Excel的表头
    function setHeaders($sheet, $mainHeaders, $subHeadersAndData) {
        //从第一行第一列开始
        $col = 1;
        $row = 1;
        //遍历主标题
        foreach ($mainHeaders as $mainHeader) {
            //设置主标题
            $sheet->setCellValueByColumnAndRow($col, $row, $mainHeader);
            //计算与当前主标题相关的子标题数量
            $subHeadersCount = count(array_filter(array_keys($subHeadersAndData), function($key) use ($mainHeader) {
                return strpos($key, $mainHeader . '_') === 0;
            }));

            //合并单元格
            if ($subHeadersCount > 0) {
                $sheet->mergeCells(Coordinate::stringFromColumnIndex($col) . $row . ':' . Coordinate::stringFromColumnIndex($col + $subHeadersCount - 1) . $row);
            }
            //更新列索引:
            $col += $subHeadersCount;
        }
    }

在这里插入图片描述

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

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

相关文章

【LeetCode算法】第108题:将有序数组转换为二叉搜索树

目录 一、题目描述 二、初次解答 三、官方解法 四、总结 一、题目描述 二、初次解答 1. 思路&#xff1a;由于数组nums是递增的&#xff0c;采用二分查找法来构造平衡二叉搜索树。首先&#xff0c;选择nums的中间结点作为根节点&#xff0c;然后将左部分的中间值作为左子树…

python下用cartopy绘制地形晕染(shading)图

python可以利用rasterio&#xff0c;cartopy&#xff0c;matplotlib等库绘制地形晕染图。 1.获取高程数据 高程数据可以从GEBCO网站下载&#xff1a;&#xff08;https://www.gebco.net/data_and_products/gridded_bathymetry_data/&#xff09;。 选择raster&#xff08;栅…

web-上传项目文件夹到Git远程仓库

Git初识 概念&#xff1a;一个免费开源&#xff0c;分布式的代码版本控制系统&#xff0c;帮助开发团队维护代码 作用&#xff1a;记录代码内容&#xff0c;切换代码版本&#xff0c;多人开发时高效合并代码内容 检验成功 打开bash终端&#xff08;git专用&#xff09;命令…

RSA密钥生成、加解密代码

背景介绍 RSA公钥加密算法是1977年由罗纳德李维斯特&#xff08;Ron Rivest&#xff09;、阿迪萨莫尔&#xff08;Adi Shamir&#xff09;和伦纳德阿德曼&#xff08;Leonard Adleman&#xff09;一起提出的。1987年首次公布&#xff0c;当时他们三人都在麻省理工学院工作。RSA…

【Linux】查看进程在哪个CPU上运行

当前服务器是多核&#xff0c;在进行性能压测时&#xff0c;需要除了要观测全局的CPU使用率&#xff0c;对于单进程单线程往往需要在一个cpu上运行&#xff0c;那如何查看进程在哪个CPU上运行呢&#xff1f; 方法一&#xff1a;taskset taskset命令主要是用来检索或设置一个处…

RTPS协议之Structure

目录 概览RTPS中的各实体和类RTPS实体和类的属性类型&#xff1a;RTPS Entities属性 HistoryCacheCacheChangeRTPS EntityRTPS ParticipantRTPS EndPointRTPS WriterRTPS Reader和DDS Entities的关联DDS DataWriterDDS DataReader 每个RTPS实体和DDS实体是一对一对应的。Histor…

Bidirectional Copy-Paste for Semi-Supervised Medical Image Segmentation

文章目录 1. 问题背景2. 本文方法2.1. 模型图2.2. 损失函数 2. 模型的训练流程图3. 实验 1. 问题背景 &#xff08;1&#xff09;在半监督医学图像分割任务中&#xff0c;标签数据和无标签数据之间存在经验失配问题。 &#xff08;2&#xff09;如果采用分隔的方式或者采用不一…

lua vm 二: 查看字节码、看懂字节码

本文讲一讲如何查看 lua 的字节码&#xff08;bytecode&#xff09;&#xff0c;以及如何看懂字节码。 以下分析基于 lua-5.4.6&#xff0c;下载地址&#xff1a;https://lua.org/ftp/ 。 1. 查看字节码 1.1 方法一&#xff1a;使用 luac luac 是 lua 自带的编译程序&#x…

Django的PATH路径转换器

本书1-7章样章及配套资源下载链接: https://pan.baidu.com/s/1OGmhHxEMf2ZdozkUnDkAkA?pwdnanc 源码、PPT课件、教学视频等&#xff0c;可以从前言给出的下载信息下载&#xff0c;大家可以评估一下。 在Django框架中&#xff0c;默认内置了一组PATH路径转换器&#xff0c;具…

Chromebook也可以安装Visual Studio Code

文章目录 ​一、Chromebook也可以安装Visual Studio Code二、chromebook硬件条件三、在chromebook上启用Linux四、安装VS Code推荐阅读 ​一、Chromebook也可以安装Visual Studio Code 在过去几年里&#xff0c;运行谷歌Chrome操作系统的Chromebook一直在作为传统笔记本电脑的…

css 图片上添加模糊背景的文字内容

html部分 <div class"onlogo"> <img src"../assets/img/banner.png" /><div class"imgText"><div class"title">一体化电子印章应用服务</div><div class"content">为企业提供安全可靠…

OverlayFS在嵌入式系统中的应用

文章目录 抛出问题基本概念使用场景OverlayFS的详细介绍框架目录合并修改文件删除文件添加文件小结 OverlayFS在嵌入式系统中的应用内核配置OverlayFS简单应用OverlayFS应用新思路 总结 环境介绍 硬件&#xff1a;T113平台 软件&#xff1a;Tina5.0 SDK&#xff08;使用的build…

RocketMQ中client_log非常大

rocketmq默认不使用logback日志&#xff0c;所以得额外配置&#xff0c;使mq使用logback配置 使用logback中的日志配置 配置MQ 使用logback的配置,具体原理见ClientLogger.java的static代码块 在应用启动函数中添加如下代码 System.*setProperty*(ClientLogger.*CLIENT_LOG_USE…

Coolmuster Android助手评测:简化Android到电脑的联系人传输

产品概述 Coolmuster Android助手是一款旨在简化Android设备与计算机之间数据管理和传输过程的全面工具。它以用户友好的界面和全面的功能&#xff0c;成为寻求高效数据管理解决方案的Android用户的热门选择。 主要特点和功能Coolmuster Android助手拥有一系列使其成为管理Andr…

TMS FNC WX Pack TMS软件分发的一组应用程序

TMS FNC WX Pack TMS软件分发的一组应用程序 TMS FNC WX Pack是由TMS软件分发的一组应用程序。这些活动是100%的跨平台和跨Frimorc&#xff0c;并在不同的应用程序中得到支持&#xff0c;如Web应用程序、Windows、Linux等。阿拉伯语视觉组件库。安装这些计算机的过程非常简单高…

postman教程-10-使用cookie

领取资料&#xff0c;咨询答疑&#xff0c;请➕wei: June__Go 上一小节我们学习了Postman Authorization授权的几种方法&#xff0c;本小节我们讲解一下Postman 使用cookie的方法。 Postman 的 cookie 管理器使您能够查看和编辑与不同域关联的 cookie。您可以为域手动创建 c…

Windows10 设置默认编码为utf-8

Windows10 设置默认编码为utf-8 序言步骤 序言 有一些程序&#xff0c;默认读取出来gbk的会报错&#xff0c;有很多都是&#xff0c;干脆就直接设置电脑为默认utf-8的&#xff0c;这样就不用担心读取成gbk的怎么样了&#xff0c;具体是否需要要看自己的程序 步骤 完成了

高端、大气、很牛B的免费wordpress模板主题

这是一款专为WordPress打造的极简主义风格主题&#xff0c;以白色和黑色为主色调&#xff0c;搭配红色点缀&#xff0c;营造出一种简洁、专业且具有视觉冲击力的效果。 该主题的设计理念是“简单即美”&#xff0c;旨在帮助用户快速搭建一个美观、易用的网站。它提供了丰富的自…

【Java】接口详解

接口是抽象类的更进一步. 抽象类中还可以包含非抽象方法, 和字段. 而接口中包含的方法都是抽象方法, 字段只能包含静态常量。 一个简单的接口代码示例 interface IShape { void draw(); } class Cycle implements IShape { Override public void draw() { System.out.println…

如何制作一本温馨的电子相册呢?

随着科技的不断发展&#xff0c;电子相册已经成为了一种流行的方式来记录和分享我们的生活。一张张照片&#xff0c;一段段视频&#xff0c;都能让我们回忆起那些温馨的时光。那么&#xff0c;如何制作一本温馨的电子相册呢&#xff1f; 首先&#xff0c;选择一款合适的电子相册…