PhpSpreadsheet_vba遍历所有sheet

PhpSpreadsheet_vba遍历所有sheet/***Excel助手*sudocomposerrequirephpoffice/phpspreadsheet*/namespaceCommonUtil;usePhpOfficePhpSpreadsheetSpreadsheet;usePhpOfficePhpSpreadsheetWriterXlsx;usePhpOfficePhpSpreadsheetStyleAlignme…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

/**

* Excel 助手

* sudo composer require phpoffice/phpspreadsheet

*/

namespace CommonUtil;

use PhpOfficePhpSpreadsheetSpreadsheet;

use PhpOfficePhpSpreadsheetWriterXlsx;

use PhpOfficePhpSpreadsheetStyleAlignment;

use PhpOfficePhpSpreadsheetStyleColor;

class ExcelUtil extends CommonUtil

{

public function __construct()

{

parent::__construct();

}

/**

* 导出数据

*/

public function exportExcel($expTitle, $expCellName, $expTableData)

{

$fileName = $expTitle;

$spreadsheet = new Spreadsheet();

// 获取活动的工作空间

$worksheet = $spreadsheet->getActiveSheet();

$cellNum = count($expCellName);

$dataNum = count($expTableData);

$cellName = array(‘A’, ‘B’, ‘C’, ‘D’, ‘E’, ‘F’, ‘G’, ‘H’, ‘I’, ‘J’, ‘K’, ‘L’, ‘M’, ‘N’, ‘O’, ‘P’, ‘Q’, ‘R’, ‘S’, ‘T’, ‘U’, ‘V’, ‘W’, ‘X’, ‘Y’, ‘Z’, ‘AA’, ‘AB’, ‘AC’, ‘AD’, ‘AE’, ‘AF’, ‘AG’, ‘AH’, ‘AI’, ‘AJ’, ‘AK’, ‘AL’, ‘AM’, ‘AN’, ‘AO’, ‘AP’, ‘AQ’, ‘AR’, ‘AS’, ‘AT’, ‘AU’, ‘AV’, ‘AW’, ‘AX’, ‘AY’, ‘AZ’);

// 合并单元格

$worksheet->mergeCells(‘A1:’.$cellName[$cellNum – 1] . ‘1’);

// 设置第一格的内容

$worksheet->setCellValue(‘A1’, $expTitle);

// 设置加粗

$worksheet->getStyle(‘A1’)->getFont()->setBold(true);

// 设置居中

$styleArray = [

‘alignment’ => [

‘horizontal’ => Alignment::HORIZONTAL_CENTER,

],

];

$worksheet->getStyle(‘A1’)->applyFromArray($styleArray);

// 设置颜色

$worksheet->getStyle(‘A1’)->getFont()->getColor()->setARGB(Color::COLOR_DARKRED);

// 设置标题

$worksheet->setTitle($expTitle);

// 设置表格菜单

for ($i = 0; $i < $cellNum; $i++) {

$worksheet->setCellValue($cellName[$i] . (+2), $expCellName[$i][1]);

$worksheet->getStyle($cellName[$i] . (+2))->getFont()->setBold(true);

// 自动宽度

$worksheet->getColumnDimension($cellName[$i])->setAutoSize(true);

}

// 设置表格内容

for ($i = 0; $i < $dataNum; $i++) {

for ($j = 0; $j < $cellNum; $j++) {

$worksheet->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);

// 支持换行

if ($expCellName[$j][2] == 1) {

$worksheet->getStyle($cellName[$j] . ($i + 3))->getAlignment()->setWrapText(true);

}

}

}

// 设置列宽为自动

// $spreadsheet->getActiveSheet()->getDefaultColumnDimension()->setWidth(20);

// $worksheet->getDefaultColumnDimension()->setAutoSize(true);

// 设置行高

$worksheet->getDefaultRowDimension()->setRowHeight(20);

header(‘Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet’);//告诉浏览器输出07Excel文件

//header(‘Content-Type:application/vnd.ms-excel’);//告诉浏览器将要输出Excel03版本文件

header(‘Content-Disposition: attachment;filename=”‘.$fileName.’.xlsx”‘);//告诉浏览器输出浏览器名称

header(‘Cache-Control: max-age=0’);//禁止缓存

$writer = new Xlsx($spreadsheet);

$writer->save(‘php://output’);

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192456.html原文链接:https://javaforall.net

(0)
上一篇 2025年12月14日 下午7:15
下一篇 2025年12月14日 下午7:43


相关推荐

  • 计算机vb语言程序设计_vb语言程序设计基础

    计算机vb语言程序设计_vb语言程序设计基础VisualBasic程序设计教程:计算机类语音编辑锁定讨论上传视频《VisualBasic程序设计教程:计算机类》是中国科学技术出版社出版的图书,作者是王东、刘福来。中文名VisualBasic程序设计教程:计算机类出版社中国科学技术出版社定价39.20作者王东刘福来ISBN9787504646798VisualBasic程序设计教程:计算机类内容简介编辑语音《全国高等…

    2022年10月7日
    4
  • VS2005 常用快捷键

    VS2005 常用快捷键

    2021年7月27日
    53
  • OpenClaw AI 助手:让网站管理从繁琐到智能的实战指南

    OpenClaw AI 助手:让网站管理从繁琐到智能的实战指南

    2026年3月14日
    3
  • 实验室设备管理系统c语言程序设计_设备管理系统怎么实现

    实验室设备管理系统c语言程序设计_设备管理系统怎么实现#include#include#includetypedefstructequipment{intnum;//编号charname[20];//名称charmodel[20];//型号charfactory[20];//厂家charbuy_date[20];//购买日期struc

    2022年10月13日
    3
  • Gogs搭建教程

    Gogs搭建教程新入公司 要求用 git 做版本控制 之前公司用的 gitlab 找资料过程中发现了 gogs 相比 gitlab 性能要求不大 所以学习搭建 Gogs 什么是 GogsGogs 是一款极易搭建的自助 Git 服务 Gogs 的目标是打造一个最简单 最快速和最轻松的方式搭建自助 Git 服务 使用 Go 语言开发使得 Gogs 能够通过独立的二进制分发 并且支持 Go 语言支持的所有平台 包括

    2026年3月17日
    2
  • 用python来开发webgame服务端(1)[通俗易懂]

    用python来开发webgame服务端(1)[通俗易懂]http://ciniao.me/article.php?id=9 刺鸟原创文章,转载请注明出处    在开始之前,先简单描述一下项目的特点:我要实现的是一个mmorpg的webgame,地图上需要看到其他的玩家,战斗系统采用半回合制的模式,所谓的半回合制,即是:采用回合制的画面布局,友方和敌方分列左右,但是战斗的中途,其他的玩家可以及时的随时插入这场战斗。当然,作为一款rpgGa

    2022年5月30日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号