PhpSpreadsheet表格导出

个人笔记记录

使用PhpSpreadsheet 导出excel。

多重表头生成excel 表

    //读取数据库public function demo1(){// 连接数据库$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;}

getSubHeadersAndData 中的数组如下。 “主表头_次级表头” 为了方便记录次级表头所属的表头是哪个。
sub_header:次级表头
data:当前列的内容。
在这里插入图片描述

    //设置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;}}

第一行是主表头。第二行是次级表头。
在这里插入图片描述

补充

对其方式
靠右:HORIZONTAL_RIGHT
靠左:HORIZONTAL_LEFT
居中:HORIZONTAL_CENTER

 // 设置该单元格左对齐
$style = $sheet->getStyleByColumnAndRow($col, $currentRow);
$style->getAlignment()->setHorizontal(Alignment::HORIZONTAL_LEFT);//合并单元格// 合并单元格,例如合并A1到B2的区域  
//方法1
$sheet->mergeCells('A1:B2');//方法2
$col = 1;//列
$row = 1;//行
//Coordinate::stringFromColumnIndex($col) //将起始列的数值索引转换为列名。
//. $row //将行号附加到列名的后面,形成起始单元格的完整坐标(如 'A1')。
//Coordinate::stringFromColumnIndex($col + $subHeadersCount - 1) //将结束列的数值索引(起始列加上需要合并的列数减 1)转换为列名。
//. $row //同样将行号附加到结束列的列名后面,形成结束单元格的完整坐标。$sheet->mergeCells(Coordinate::stringFromColumnIndex($col) . $row . ':' . Coordinate::stringFromColumnIndex($col + $subHeadersCount - 1) . $row);

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【ROS2大白话】三、给turtlebot3安装realsense深度相机

系列文章目录 【ROS2大白话】一、ROS2 humble及cartorgrapher安装 【ROS2大白话】二、turtlebot3安装 【ROS2大白话】三、给turtlebot3安装realsense深度相机 【ROS2大白话】四、ROS2非常简单的传参方式 文章目录 系列文章目录效果展示一、修改model.sdf文件1. 路径位置2. 修改…

【Linux取经路】网络套接字编程——初识篇

文章目录 一、端口号1.1 认识端口号1.2 端口号 VS 进程 PID 二、认识 TCP 协议三、认识 UDP四、网络字节序列五、socket 编程接口5.1 常用 API5.2 sockaddr 结构 六、结语 一、端口号 网络通信的本质是应用层软件进行数据的发送和接受&#xff0c;软件在启动之后&#xff0c;本…

基于RNN和Transformer的词级语言建模 代码分析 _generate_square_subsequent_mask

基于RNN和Transformer的词级语言建模 代码分析 _generate_square_subsequent_mask flyfish Word-level Language Modeling using RNN and Transformer word_language_model PyTorch 提供的 word_language_model 示例展示了如何使用循环神经网络RNN(GRU或LSTM)和 Transforme…

顶顶通呼叫中心中间件-同振和顺振配置步骤(mod_cti基于FreeSWITCH)

顶顶通呼叫中心中间件-同振和顺振配置步骤(mod_cti基于FreeSWITCH) 一、拨号方案配置 1、同振 win-ccadmin配置方法 1、点击拨号方案->2、在红框中输入同振->3、点击添加->4、根据图中配置&#xff0c;配置好了等待一分钟即可生效。 web-ccadmin配置方法 2、顺振…

关于浔川python社在全网博主原力月度排名泸州地区排名第三名的调查——浔川总社部

6月6日&#xff0c;浔川python社在全网博主原力月度排名泸州地区排名第三名。 引起了广大python爱好者等的不满&#xff0c;为什么浔川python社这么一个大的python社排名第三&#xff1f; 2024-06-04 21:59:52 浔川python社在全网博主原力月度排名泸州地区排名第一名。 2024-…

重复文件怎么查找并清理,试试这5个文件去重方法(新)

重复文件怎么查找并清理&#xff1f;日常工作中&#xff0c;我们使用电脑的时间长了&#xff0c;都会累积大量好的文件&#xff0c;这其中难免会出现重复文件。这些重复文件不仅占用了电脑磁盘空间&#xff0c;还会降低电脑性能。因此&#xff0c;我们必须定期对重复文件查找出…

每日两题 / 198. 打家劫舍 74. 搜索二维矩阵(LeetCode热题100)

198. 打家劫舍 - 力扣&#xff08;LeetCode&#xff09; dp[i]表示考虑前i 1号房屋&#xff0c;能获取的最大金额。对于没一间房屋都有偷与不偷两种选择 如果偷&#xff0c;需要从dp[i - 2]转移&#xff0c;因为不能偷窃相邻房屋&#xff0c;dp[i] dp[i - 2] nums[i] 如果…

【Linux取经路】信号的发送与保存

文章目录 一、重新理解发送信号二、信号的保存、阻塞信号的概念三、信号集操作函数3.1 sigprocmask3.2 sigpending 四、阻塞信号代码验证五、结语 一、重新理解发送信号 进程通过位图来实现对普通信号&#xff08;1-31号信号&#xff09;的保存&#xff0c;该位图保存在进程的…

【漏洞复现】I Doc View 在线文档预览 qJvqhFt.json 任意文件读取漏洞(XVE-2024-2115)

0x01 产品简介 iDocView是一个在线文档解析应用&#xff0c;旨在提供便捷的文件查看和编辑服务。 0x02 漏洞概述 iDocView是一个在线文档预览系统 /iew/gJvghftjson 接口处存在任意文件读取漏洞&#xff0c;未授权的攻击者可以利用此接口并携带默认token读取服务器敏感文件信…

面试Tip--java创建对象的四种方式

java创建对象一共有四种方式&#xff0c;但是我们在写代码的时候用的new 关键字偏多&#xff0c;像一些接口对接则是序列化创建对象偏多&#xff0c;今天我们来简单介绍下使用场景以及各个方式 1. 使用 new 关键字 这是最常见的创建对象的方式。 public class Example {priva…

【AIGC X UML 落地】通过多智能体实现自然语言绘制UML图

前天写了篇博文讲到用PlantUML来绘制C类图和流程图。后台有读者留言&#xff0c;问这步能否自动化生成&#xff0c;不想学习 PlantUML 语法。 我想了下&#xff0c;发现这事可行&#xff0c;确实可以做到通过自然语言的描述就能实现 UML图的绘制&#xff0c;昨天晚上加了个班到…

统信UOS SSH服务升级(ubuntu20)内网

服务器配置 系统信息 SSH版本 目标版本 openssh-server_8.2p1-4_arm64.deb 因为不通互联网&#xff0c;所以所有deb包需要手动下载&#xff08;可以连接互联网的可以自动忽略手动下载deb步骤&#xff0c;直接apt-get install xxx 即可&#xff09; 升级步骤 !!!deb下载方式…

在Jenkins 中使用 NVM 管理 Node.js 部署项目的自动化脚本

在Jenkins 中使用 NVM 管理 Node.js 部署项目的自动化脚本 人生旅途&#xff0c;总有人不断地走来&#xff0c;有人不断地离去。当新名字变成老名字&#xff0c;当老的名字渐渐模糊&#xff0c;又是一个故事的结束和另一个故事的开始。 在现代软件开发中&#xff0c;持续集成/持…

Windows11下Docker使用记录(五)

目录 准备1. WSL安装cuda container toolkit2. win11 Docker Desktop 设置3. WSL创建docker container并连接cuda4. container安装miniconda&#xff08;可选&#xff09; Docker容器可以从底层虚拟化&#xff0c;使我们能够在 不降级 CUDA驱动程序的情况下使用 任何版本的CU…

支付宝小众玩法 爱溜达的人不容错过

创建一个简单的程序来帮助用户管理他们的图片&#xff0c;例如筛选分辨率合适、尺寸适中的图片来准备上传&#xff0c;这是一个技术上合理且有益的方向。例如&#xff0c;一个Python脚本使用Pillow库来检查文件夹中图片的尺寸&#xff1a; from PIL import Image import os# 根…

可视化数据科学平台在信贷领域应用系列五:零代码可视化建模

信贷风控模型是金融机构风险管理的核心工具&#xff0c;在信贷风险管理工作中扮演着至关重要的角色。随着信贷市场的环境不断变化&#xff0c;信贷业务的风险日趋复杂化和隐蔽化&#xff0c;开发和应用准确高效的信贷风控模型显得尤为重要。信贷风险控制面临着越来越大的挑战和…

【MySQL数据库】:MySQL内外连接

目录 内外连接和多表查询的区别 内连接 外连接 左外连接 右外连接 简单案例 内外连接和多表查询的区别 在 MySQL 中&#xff0c;内连接是多表查询的一种方式&#xff0c;但多表查询包含的范围更广泛。外连接也是多表查询的一种具体形式&#xff0c;而多表查询是一个更…

React-生成随机数和日期格式化

生成随机数 uuid文档&#xff1a;https://github.com/uuidjs/uuid npm install uuid import {v4 as uuidV4} from uuid 使用&#xff1a; uuidV4() 日期格式化 dayjs文档&#xff1a;安装 | Day.js中文网 npm install dayjs import dayjs from dayjs

LCTF 2018 bestphp‘s revenge

考点:Soap原生类Session反序列化CRLF注入 <?php highlight_file(__FILE__); $b implode; call_user_func($_GET[f], $_POST); session_start(); if (isset($_GET[name])) { $_SESSION[name] $_GET[name]; } var_dump($_SESSION); $a array(reset($_…

MySQL学习——选项文件的使用

MySQL 的许多程序都可以从选项文件&#xff08;有时也被称为配置文件&#xff09;中读取启动选项。选项文件提供了一种方便的方式来指定常用的选项&#xff0c;这样你就不必每次运行程序时都在命令行上输入这些选项。 要确定一个程序是否读取选项文件&#xff0c;你可以使用 -…