如何使用PhpSpreadsheet将数组数据导出并合并行生成Excel表格?

使用phpspreadsheet导出并合并excel表格行数据

本文介绍如何利用PhpSpreadsheet库将数组数据导出为Excel表格,并实现行合并效果。假设您有一个如下所示的数组:

[    "customer" => "西卡若卡",    "product" => [        [            "name" => "瓶-500ml塑料瓶",            "parts" => "24牙35克",            "rongliang" => "500ml"        ],        [            "name" => "内塞-500ml塑料瓶",            "parts" => "19小孔内塞+盖板",        ],        [            "name" => "盖子-500ml塑料瓶",            "parts" => "24牙双层pp盖",        ],    ]]

目标是将其导出为Excel表格,并合并客户名称所在的行,效果如下图所示:

如何使用PhpSpreadsheet将数组数据导出并合并行生成Excel表格?

PhpSpreadsheet 提供了 mergeCells() 方法来合并单元格。以下代码演示了如何使用该方法实现行合并:

立即学习“PHP免费学习笔记(深入)”;

use PhpOfficePhpSpreadsheetSpreadsheet;use PhpOfficePhpSpreadsheetWriterXlsx;$spreadsheet = new Spreadsheet();$sheet = $spreadsheet->getActiveSheet();$data = [    "customer" => "西卡若卡",    "product" => [        [            "name" => "瓶-500ML塑料瓶",            "parts" => "24牙35克",            "rongliang" => "500ML"        ],        [            "name" => "内塞-500ML塑料瓶",            "parts" => "19小孔内塞+盖板",        ],        [            "name" => "盖子-500ML塑料瓶",            "parts" => "24牙双层PP盖",        ],    ]];$sheet->setCellValue('A1', '客户');$sheet->setCellValue('B1', '产品名称');$sheet->setCellValue('C1', '部件');$sheet->setCellValue('D1', '容量');$row = 2;foreach ($data['product'] as $product) {    $sheet->setCellValue('A' . $row, $data['customer']);    $sheet->setCellValue('B' . $row, $product['name']);    $sheet->setCellValue('C' . $row, $product['parts']);    if (isset($product['rongliang'])) {        $sheet->setCellValue('D' . $row, $product['rongliang']);    }    $row++;}// 合并客户列$sheet->mergeCells('A2:A' . ($row - 1));$writer = new Xlsx($spreadsheet);$writer->save('example.xlsx');

这段代码首先设置表头,然后循环遍历数组数据写入单元格。最后,使用 mergeCells('A2:A' . ($row - 1)) 合并从 A2 到 A(最后一行) 的单元格。 请确保您已正确安装 PhpSpreadsheet 库。 运行此代码将生成一个名为 example.xlsx 的 Excel 文件,其中包含合并后的行数据。 此方法清晰地展示了如何使用 PhpSpreadsheet 实现数组数据导出和单元格合并。

以上就是如何使用PhpSpreadsheet将数组数据导出并合并行生成Excel表格?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1256404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Swoole 协程中 sleep 为什么会导致死锁?
上一篇 2025年12月10日 03:53:05
如何通过nginx配置确保只有index.php文件可以被访问,而其他文件被禁止访问?
下一篇 2025年12月10日 03:53:12

相关推荐

  • 如何在H5环境中实现EXCEL和Word文件的在线预览?

    H5环境下EXCEL和Word文件在线预览技术详解 在如今的Web应用中,在线预览文档功能至关重要,尤其对于需要处理大量文件的企业应用。本文将介绍两种无需插件,直接在浏览器中预览EXCEL和Word文件的方法。 企业对在线文档预览的需求日益增长,以提高效率和协同性。下面我们探讨两种有效的H5在线预览…

    2026年5月10日
    000
  • 如何从Google Drive中恢复被转换为GDoc的原始HTML文件

    当HTML文件上传至Google Drive后被自动转换为Google Docs格式时,用户可能无法直接下载原始HTML文件。本教程将详细指导您如何利用Google Docs的版本历史功能,找到并下载最初上传的HTML文件,解决下载时仅获取渲染视图而非原始文件的问题。 引言:Google Drive…

    2026年5月10日
    000
  • PHPSpreadsheet:复制Excel单元格内容与样式的教程

    phpspreadsheet复制单元格时,直接获取值的方法无法保留样式。本教程详细介绍了如何通过分离值和样式处理,先获取源单元格的样式数组,再将其应用到目标单元格,从而实现单元格内容及其格式的完整复制。 引言 在使用PHPSpreadsheet处理Excel文件时,开发者常常需要将一个单元格的内容连…

    2026年5月10日
    000
  • PHPSpreadsheet:实现单元格值与格式同步复制的专业指南

    本教程详细介绍了如何使用phpspreadsheet库在excel文件中复制单元格内容及其完整的样式格式。不同于仅复制值的`getvalue`等方法,我们将学习如何通过导出源单元格的样式数组,并将其应用到目标单元格,从而实现数据与格式的同步迁移,确保复制后的单元格外观保持一致。 在使用PHPSpre…

    2026年5月10日
    100
  • html5如何读取word_HTML5读取Word文档方法与文件解析技巧【教程】

    可在浏览器中用前端技术解析.docx文件:一、mammoth.js转HTML;二、JSZip+docxtemplater读XML;三、Office.js仅限加载项;四、原生JSZip手动解压提取。 如果您希望在浏览器中直接读取 Word 文档内容,但 Word 文件(.docx)本质上是 ZIP 压…

    2026年5月10日
    000
  • C++如何实现建造者 C++建造者模式的设计

    C++如何实现建造者 C++建造者模式的设计C++如何实现建造者 C++建造者模式的设计C++如何实现建造者 C++建造者模式的设计C++如何实现建造者 C++建造者模式的设计

    建造者模式与工厂模式的区别在于,工厂模式用于创建不同类型的对象,而建造者模式专注于构建复杂对象的不同部分。1. 工厂模式通常一步返回完整对象;2. 建造者模式允许逐步构建并控制过程;3. 建造者适用于对象构建复杂、需灵活配置组件的情况;4. 建造者避免构造函数臃肿,提高可维护性;5. c++++中通…

    2026年5月10日 用户投稿
    000
  • HTML文件选择器accept属性为何无法有效过滤CSV文件?

    html文件上传控件accept属性无法有效过滤csv文件? 网页开发中,我们常使用元素让用户选择文件上传。accept属性用于限制可选择的文件类型,提升用户体验和安全性。然而,该属性并非总是完美运行。本文分析accept属性无法正确过滤CSV文件的问题,并提供解决方案。 问题: 开发者希望仅允许上…

    2026年5月10日
    000
  • 如何使用jq、jszip.js、FileSaver.js高效导出Excel表格并自定义样式?

    高效导出excel表格并自定义样式:基于jq、jszip.js、filesaver.js和exceljs 本文介绍如何利用jq、jszip.js、FileSaver.js以及更强大的exceljs插件导出Excel表格,并灵活调整列顺序和单元格样式。 许多用户在导出表格时,需要调整列顺序(例如,交换…

    2026年5月10日
    000
  • 如何在Excel中构建自定义多级表格结构?

    构建Excel自定义多层级表格结构 需要在Excel表格中添加自定义字段和多层级结构?本文提供几种方法,助您轻松实现: 方法一:借助JSON表单构建器 利用JSON表单构建器(例如:https://www.php.cn/link/a1bdeb626662373c4e0f1784388a52b7),创…

    2026年5月10日
    000
  • HTML 文件选择器 MIME 类型设置失效的原因和解决方案?

    文件选择器设置 mime 类型失效问题 问题: 使用 HTML 文件选择器时,设置了多种文件类型的 MIME 类型,但部分类型未能生效,例如 CSV 文件。 代码: 原因: 默认情况下,文件选择器会将 MIME 类型视为 AND 逻辑,这意味着所有指定的 MIME 类型都必须匹配才能生效。因此,当没…

    2026年5月10日
    000
  • KMS Tools 20260203 神龙KMS激活工具合集

    KMS Tools Portable是一款激活windows和office的工具合集包,此软件集合老外@Ratiborus制作的其他几个软件。相当的实用,且安全便携无毒。可以激活最新的WIN10 、WIN8全系列、WIN7 Office2016、Visio2016、Project2016、OFFIC…

    2026年4月21日
    801
  • CSS 太棒了!

    我正在学习什么 css 赋予了页面活力。多年来,css 变得越来越强大,并且已经开始用于制作以前需要 javascript 的动画。本周我一直在研究它的一些更高级的属性。 媒体查询 媒体查询几乎已经成为新时代设备的必需品。随着智能手机的出现,通过手机消费媒体的人比任何其他设备都多。因此,网站必须在移…

    2025年12月24日
    300
  • html5能否插入在线文档链接_html5在线文档嵌入与权限设置【教程】

    HTML5中嵌入在线文档需根据来源选择方案:一、用iframe嵌入Google Docs等公开文档,须设“任何人可查看”;二、通过OnlyOffice等第三方服务中转,确保响应头允许嵌入;三、用object/embed加载PDF,需服务器配置CORS;四、无法修改源站时,可用服务端代理过滤禁用响应头…

    2025年12月23日
    000
  • 如何将文件存为html_将其他格式文件保存为HTML格式【保存】

    可将非HTML文档转为浏览器可打开的HTML文件,方法包括:一、Word另存为网页;二、Typora导出Markdown;三、记事本手写HTML代码保存;四、LibreOffice导出HTML;五、在线工具转换。 如果您拥有非HTML格式的文档(如Word、Markdown、纯文本等),但需要将其转…

    2025年12月23日
    000
  • 如何使文档变成html_将文档转换为HTML格式步骤【格式】

    可将普通文档转为HTML文件,方法包括:一、用Word等软件导出;二、手写HTML代码;三、用pandoc等工具转Markdown;四、借助在线服务;五、用Python脚本批量处理。 如果您拥有一份普通文档(如Word、纯文本或Markdown格式),但需要将其呈现为可在浏览器中打开的HTML文件,…

    2025年12月23日
    000
  • Python f-string 中字面量大括号的正确使用与转义

    在 python 的 f-string 中嵌入包含大括号的字符串(如 javascript 代码或 json)时,必须对字面量大括号进行转义。f-string 会将单层大括号 `{}` 视为表达式占位符,因此需要使用双层大括号 `{{}}` 来表示实际的字面量大括号,从而避免语法解析错误,确保字符串…

    2025年12月23日
    000
  • html转excel工具_html转excel网页版转换器

    答案:html转excel工具可在Convertio官网使用。该平台支持在线将HTML表格转换为Excel,无需安装软件,提供批量上传、保留格式、智能识别等功能,适用于多场景数据整理,操作简单且保障隐私安全。 html转excel工具_html转excel网页版转换器在哪里?这是不少网友都关注的,接…

    2025年12月23日
    000
  • 如何强制Microsoft Edge浏览器直接下载Office文件而非在线预览

    本文旨在解决Microsoft Edge浏览器在处理Office文件超链接时,默认启用在线预览而非直接下载的问题。通过修改服务器(以Nginx为例)的HTTP响应头,特别是设置Content-Disposition: attachment和Content-Type: application/octe…

    2025年12月23日
    000
  • html转word工具_html转word网页版入口

    html转word网页版入口是https://www.htmltowordconverter.com,该平台支持HTML文档转换为Word文件,保留排版与样式,兼容本地上传和URL导入,提供实时预览与批量处理功能;界面简洁无需安装软件,支持主流浏览器,转换高效稳定;输出文件保持字体、颜色、图片布局,…

    2025年12月23日
    200
  • 强制Edge浏览器直接下载Office文件:Nginx配置指南

    microsoft edge在下载office文件时可能自动跳转至在线预览,影响用户体验。本文提供一种服务器端解决方案,通过配置nginx,为office文件下载请求添加特定的http响应头`content-disposition: attachment`和`content-type: applic…

    2025年12月23日
    100

发表回复

登录后才能评论
关注微信