0

0

PHP解析Excel文件教程_PHP读写Excel的方式

舞夢輝影

舞夢輝影

发布时间:2025-12-16 21:17:18

|

978人浏览过

|

来源于php中文网

原创

PHP需借助PhpSpreadsheet库读写Excel,支持多种格式;安装推荐Composer,要求PHP≥7.4并启用zip/xml/mbstring扩展;读取用IOFactory::load(),写入新建Spreadsheet实例并用Writer导出;处理大文件应启用只读模式、逐行读取并及时释放内存。

php解析excel文件教程_php读写excel的方式

PHP本身不直接支持Excel文件的读写,需借助第三方库。最常用、最稳定的是 PhpSpreadsheetphpoffice/phpspreadsheet),它是PHPExcel的官方继任者,支持.xlsx、.xls、.csv等多种格式,功能全面且持续维护。

安装PhpSpreadsheet

推荐使用Composer安装:

  • 运行命令:composer require phpoffice/phpspreadsheet
  • 确保PHP版本 ≥ 7.4(建议8.0+),并启用zipxmlmbstring扩展
  • 如无法用Composer,可手动下载源码并require autoload.php

读取Excel文件(.xlsx/.xls)

核心是IOFactory::load()加载文件,再通过工作表对象获取数据:

  • 加载文件:$spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load('data.xlsx');
  • 获取默认工作表:$sheet = $spreadsheet->getActiveSheet();
  • 读取单个单元格:$value = $sheet->getCell('A1')->getValue();
  • 读取整行或整列可用rangeToArray(),例如:$data = $sheet->rangeToArray('A1:D10');
  • 遍历所有行更安全的方式是用getHighestRow()getHighestColumn()动态判断范围

写入Excel文件并导出

新建表格后设置单元格值,再用Writer输出:

讯飞绘文
讯飞绘文

讯飞绘文:免费AI写作/AI生成文章

下载

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

  • 新建实例:$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
  • 写入内容:$spreadsheet->getActiveSheet()->setCellValue('A1', '姓名')->setCellValue('B1', '年龄');
  • 批量写入二维数组:$spreadsheet->getActiveSheet()->fromArray($data, NULL, 'A2');
  • 保存为文件:$writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
    $writer->save('output.xlsx');
  • 浏览器直接下载:设置Header + php://output,注意清空缓冲区

处理大文件与内存优化

读取超大Excel(如10万行以上)容易OOM,可用以下方式缓解:

  • 启用“只读”和“按需加载”模式:$reader = \PhpOffice\PhpSpreadsheet\IOFactory::createReader('Xlsx');
    $reader->setReadDataOnly(true);
    $reader->setLoadSheetsOnly(['Sheet1']);
  • 逐行读取(使用getRowIterator()而非一次性转数组)
  • 避免在循环中反复调用getCell(),改用getCellByColumnAndRow($col, $row)更高效
  • 处理完及时unset($spreadsheet)释放内存

基本上就这些。用好PhpSpreadsheet,读写Excel在PHP里并不复杂,但细节(比如编码、日期格式、公式计算、样式保留)容易忽略,按需查阅文档即可。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.12.25

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

237

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

499

2024.03.01

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1904

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2094

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1086

2024.11.28

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1402

2023.07.25

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.6万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号