在php开发中处理excel文件的关键在于选择合适的工具phpspreadsheet并掌握其基本用法。1. 推荐使用phpspreadsheet库,它是phpexcel的继任者,支持xls、xlsx格式,可通过composer安装。2. 读取excel文件流程为加载文件、获取工作表、遍历单元格内容,可使用getrowiterator和getcelliterator逐行逐列读取数据,并注意处理空单元格及公式计算值。3. 写入操作包括创建对象、设置单元格内容、使用xlsx写入器保存文件,同时需注意内存管理和文件路径权限问题。4. 常见问题包括中文乱码应检查环境与打开方式,性能问题可通过优化缓存与减少对象创建解决,文件类型识别错误可手动指定读取类型,复杂样式可能无法完全还原。

在PHP开发中,处理Excel文件的需求很常见,比如导出报表、批量导入数据等。实现这些功能并不复杂,关键在于选对工具和掌握基本用法。
1. 推荐使用的库:PhpSpreadsheet
目前最主流的处理Excel的PHP库是 PhpSpreadsheet,它是PHPExcel的继任者,支持读写xls、xlsx等多种格式。安装起来也很方便,可以通过 Composer 安装:
composer require phpoffice/phpspreadsheet
这个库文档齐全,社区活跃,适合大多数项目使用。
立即学习“PHP免费学习笔记(深入)”;
2. 如何读取Excel文件中的数据
读取Excel文件的基本流程是:加载文件 → 获取工作表 → 遍历单元格内容。例如:
require 'vendor/autoload.php';
use PhpOffice\PhpSpreadsheet\IOFactory;
$inputFileName = './data.xlsx';
$spreadsheet = IOFactory::load($inputFileName);
$worksheet = $spreadsheet->getActiveSheet();
foreach ($worksheet->getRowIterator() as $row) {
$cellIterator = $row->getCellIterator();
$cellIterator->setIterateOnlyExistingCells(false);
$rowData = [];
foreach ($cellIterator as $cell) {
$rowData[] = $cell->getValue();
}
// 处理每一行数据
}- 如果你不确定使用哪个工作表,可以用
getSheet(0)来指定第一个工作表。 - 可以通过
$cell->getCalculatedValue()获取公式计算后的值。 - 注意有些单元格可能是空的,需要做判断避免错误。
3. 写入数据到Excel文件
写入操作包括创建新文件、填充数据、保存为Excel格式。示例代码如下:
XYCMS建站系统PHP版非MVC框架,自己手写原生态普通代码,作为企业用,已经绰绰有余。软件运行效率中等,加入数据缓存后性能提高。假如用来学习,下载可以慢慢研究的,假如用来建站,可以选择购买商业版就行建站用。栏目类别:文章,人员信息,专题项目,招聘,下载,相册,单页【支持无限极分类】文章:可用作添加新闻,资讯,列表信息类栏目信息人员信息:可用作企业员工信息栏目内容添加或者维护专题项目:可用作企业
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
// 设置单元格内容
$sheet->setCellValue('A1', '姓名');
$sheet->setCellValue('B1', '年龄');
$sheet->setCellValue('A2', '张三');
$sheet->setCellValue('B2', 25);
// 保存为Excel文件
$writer = new Xlsx($spreadsheet);
$writer->save('output.xlsx');- 支持设置样式(字体、颜色、边框等),但会稍微复杂一些。
- 导出大量数据时注意内存问题,可以使用缓存设置或分批次写入。
- 文件保存路径要确保有写权限。
4. 常见问题与注意事项
中文乱码:保存文件时默认编码没问题,但如果出现乱码,建议检查服务器环境和文件打开方式。
性能问题:处理大文件时容易占用较多内存,可通过关闭不必要的缓存、减少对象创建来优化。
-
文件类型识别错误:有时候自动识别文件类型失败,可以手动指定读取类型,如:
$reader = IOFactory::createReader('Xlsx'); $spreadsheet = $reader->load("file.xlsx"); 样式丢失:读取某些带复杂样式的Excel文件时,可能无法完全还原原样。
基本上就这些,掌握了 PhpSpreadsheet 的基本用法后,处理Excel文件就会变得简单多了。










