PHP高效、轻量级表格数据处理库 OpenSpout ,很好用
OpenSpout 是一个高效、轻量级的 PHP 库,用于处理电子表格文件(如 Excel 和 CSV)。它支持读取和写入大型文件,且内存占用低。本文将详细介绍如何安装和使用 OpenSpout。
目录
-
安装
-
基本使用
-
高级功能
-
参考文档
安装
OpenSpout 可以通过 Composer 安装。确保你已经安装了 Composer,然后在项目根目录下运行以下命令:
composer require openspout/openspout
安装完成后,Composer 会自动加载 OpenSpout。
基本使用
读取 Excel 文件
以下是一个读取 Excel 文件的示例:
require 'vendor/autoload.php';use OpenSpout\Reader\Common\Creator\ReaderEntityFactory;// 创建 Reader 对象
$reader = ReaderEntityFactory::createXLSXReader();// 打开文件
$reader->open('example.xlsx');foreach ($reader->getSheetIterator() as $sheet) {foreach ($sheet->getRowIterator() as $row) {// 处理每一行数据$cells = $row->getCells();print_r($cells);}
}// 关闭 Reader
$reader->close();
写入 Excel 文件
以下是一个写入 Excel 文件的示例:
require 'vendor/autoload.php';use OpenSpout\Writer\Common\Creator\WriterEntityFactory;
use OpenSpout\Common\Entity\Row;// 创建 Writer 对象
$writer = WriterEntityFactory::createXLSXWriter();// 打开文件
$writer->openToFile('output.xlsx');// 创建行数据
$rows = [WriterEntityFactory::createRowFromArray(['Name', 'Age', 'City']),WriterEntityFactory::createRowFromArray(['John Doe', 30, 'New York']),WriterEntityFactory::createRowFromArray(['Jane Doe', 25, 'Los Angeles']),
];// 写入行数据
foreach ($rows as $row) {$writer->addRow($row);
}// 关闭 Writer
$writer->close();
读取 CSV 文件
以下是一个读取 CSV 文件的示例:
require 'vendor/autoload.php';use OpenSpout\Reader\Common\Creator\ReaderEntityFactory;// 创建 Reader 对象
$reader = ReaderEntityFactory::createCSVReader();// 打开文件
$reader->open('example.csv');foreach ($reader->getSheetIterator() as $sheet) {foreach ($sheet->getRowIterator() as $row) {// 处理每一行数据$cells = $row->getCells();print_r($cells);}
}// 关闭 Reader
$reader->close();
写入 CSV 文件
以下是一个写入 CSV 文件的示例:
require 'vendor/autoload.php';use OpenSpout\Writer\Common\Creator\WriterEntityFactory;
use OpenSpout\Common\Entity\Row;// 创建 Writer 对象
$writer = WriterEntityFactory::createCSVWriter();// 打开文件
$writer->openToFile('output.csv');// 创建行数据
$rows = [WriterEntityFactory::createRowFromArray(['Name', 'Age', 'City']),WriterEntityFactory::createRowFromArray(['John Doe', 30, 'New York']),WriterEntityFactory::createRowFromArray(['Jane Doe', 25, 'Los Angeles']),
];// 写入行数据
foreach ($rows as $row) {$writer->addRow($row);
}// 关闭 Writer
$writer->close();
高级功能
处理大型文件
OpenSpout 通过流式处理支持大型文件,避免内存溢出。以下是一个处理大型文件的示例:
require 'vendor/autoload.php';use OpenSpout\Reader\Common\Creator\ReaderEntityFactory;// 创建 Reader 对象
$reader = ReaderEntityFactory::createXLSXReader();// 打开文件
$reader->open('large_file.xlsx');foreach ($reader->getSheetIterator() as $sheet) {foreach ($sheet->getRowIterator() as $row) {// 处理每一行数据$cells = $row->getCells();print_r($cells);}
}// 关闭 Reader
$reader->close();
自定义样式
OpenSpout 允许你自定义单元格样式。以下是一个自定义样式的示例:
require 'vendor/autoload.php';use OpenSpout\Writer\Common\Creator\WriterEntityFactory;
use OpenSpout\Common\Entity\Style\Style;
use OpenSpout\Common\Entity\Row;// 创建 Writer 对象
$writer = WriterEntityFactory::createXLSXWriter();// 打开文件
$writer->openToFile('styled_output.xlsx');// 创建样式
$style = (new Style())->setFontBold()->setFontSize(14)->setFontColor(Color::BLUE)->setBackgroundColor(Color::YELLOW);// 创建行数据
$rows = [WriterEntityFactory::createRowFromArray(['Name', 'Age', 'City'], $style),WriterEntityFactory::createRowFromArray(['John Doe', 30, 'New York']),WriterEntityFactory::createRowFromArray(['Jane Doe', 25, 'Los Angeles']),
];// 写入行数据
foreach ($rows as $row) {$writer->addRow($row);
}// 关闭 Writer
$writer->close();
参考文档
-
OpenSpout 官方文档
-
GitHub 仓库
通过本文,你应该已经掌握了 OpenSpout 的基本安装和使用方法。希望这对你处理电子表格文件有所帮助!
相关文章:
PHP高效、轻量级表格数据处理库 OpenSpout ,很好用
OpenSpout 是一个高效、轻量级的 PHP 库,用于处理电子表格文件(如 Excel 和 CSV)。它支持读取和写入大型文件,且内存占用低。本文将详细介绍如何安装和使用 OpenSpout。 目录 安装 基本使用 高级功能 参考文档 安装 OpenSp…...
2010年上半年软件设计师考试上午真题的知识点整理(附真题及答案解析)
以下是2010年上半年软件设计师考试上午真题的知识点分类整理,涉及定义的详细解释,供背诵记忆。 1. 计算机组成原理 CPU与存储器的访问。 Cache的作用: 提高CPU访问主存数据的速度,减少访问延迟。存储器的层次结构: 包括寄存器、Cache、主存和…...
EventSource的使用
什么是EventSource EventSource 是一个用于服务器推送事件(Server-Sent Events, SSE)的接口,它允许服务器推送实时更新到浏览器。与 WebSocket 不同,SSE 是单向的(服务器到客户端),适用于更新频…...
【第12章:深度学习与伦理、隐私—12.3 深度学习模型的透明性与可解释性提升策略】
凌晨三点的ICU病房,AI辅助诊断系统将一位患者的肺炎误判为普通感冒——当主治医生要求查看诊断依据时,系统只能给出冷冰冰的概率数值。这场惊心动魄的误诊事件,掀开了深度学习可解释性危机的冰山一角。 一、模型透明的"第一性原理" 1.1 可解释性的三维度量 