0

0

php怎么导出Excel_使用PhpSpreadsheet生成Excel文件【技巧】

蓮花仙者

蓮花仙者

发布时间:2026-01-03 22:02:34

|

454人浏览过

|

来源于php中文网

原创

phpspreadsheet 是当前 php 导出 excel 最可靠的选择,替代已废弃的 phpexcel;支持 .xlsx、.xls、.csv 等格式但默认仅生成 .xlsx,需手动设置响应头否则浏览器乱码或下载为空;必须用 composer 安装,v2.0+ 要求 php ≥ 8.0,php 7.4 需锁定 ^1.26 版本;导出核心四步:创建 spreadsheet、获取工作表、写入数据、设置响应头后 save('php://output');csv 导出需手动转义特殊字符;大数据量导出需禁用公式计算、分批写入并调优内存与超时配置。

php怎么导出excel_使用phpspreadsheet生成excel文件【技巧】

PhpSpreadsheet 是当前 PHP 导出 Excel 最可靠的选择,替代已废弃的 PHPExcel;它支持 .xlsx.xls.csv 等格式,但默认只生成 .xlsx,且不直接输出 Excel 二进制流——必须手动设置响应头,否则浏览器会乱码或下载为空文件。

安装 PhpSpreadsheet 并确认最低 PHP 版本

用 Composer 安装是唯一推荐方式,避免手动引入类文件导致的自动加载失败:

composer require phpoffice/phpspreadsheet

注意:phpspreadsheet v2.0+ 要求 PHP ≥ 8.0;若项目仍在用 PHP 7.4,必须锁定版本:

composer require phpoffice/phpspreadsheet:^1.26
  • PHP 7.4 只能用 ^1.26,更高版本会报 ParseError: syntax error, unexpected token "string"
  • Composer 安装后无需 requireinclude,Autoloader 自动加载所有类
  • 不要混用 PHPExcelPhpSpreadsheet 的命名空间,否则类找不到

写入数据并正确触发浏览器下载

导出失败最常见原因是没设置响应头,或调用 ob_end_clean() 不及时,导致额外空格/HTML 混入 Excel 流。核心四步不能少:

Deja Videos
Deja Videos

AI视频内容编辑工具

下载

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

  • 创建 Spreadsheet 实例,用 getActiveSheet() 获取工作表
  • setCellValue()fromArray() 写入数据(后者适合二维数组)
  • 创建 Xlsx writer,并用 save('php://output') 输出到响应体
  • save() 设置完整响应头,且确保之前无任何输出(包括空行、BOM、echo
<?php
require 'vendor/autoload.php';

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
$sheet->fromArray([
    ['姓名', '年龄', '城市'],
    ['张三', 28, '北京'],
    ['李四', 32, '上海'],
]);

// ⚠️ 必须在 save() 前执行,且不能有任何前置输出
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="users.xlsx"');
header('Cache-Control: max-age=0');

$writer = new Xlsx($spreadsheet);
$writer->save('php://output');
exit;
?>

导出 CSV 时字段含逗号、换行或引号的处理

直接用 setCellValue() 写 CSV 容易破坏格式,因为 PhpSpreadsheet 的 Csv writer 本身不自动包裹字段(如 "abc,def")。必须手动预处理数据:

  • 对每个单元格值调用 fputcsv() 风格转义:含 ," 或换行符的字段,需用双引号包裹,且内部双引号要变成两个("""
  • 不要用 fromArray() 直接塞原始数据,应先遍历清洗
  • Csv writer 不支持样式、多工作表,仅用于纯文本导出
$data = [
    ['name' => '王"五', 'desc' => "喜欢编程,\n也爱跑步"],
    ['name' => '赵六', 'desc' => '普通用户']
];

$cleaned = [];
foreach ($data as $row) {
    $cleaned[] = array_map(function($v) {
        // 简单 CSV 转义:含特殊字符就加引号,内部引号翻倍
        if (preg_match('/[",\n\r]/', $v)) {
            return '"' . str_replace('"', '""', $v) . '"';
        }
        return $v;
    }, $row);
}

$spreadsheet = new Spreadsheet();
$spreadsheet->getActiveSheet()->fromArray($cleaned);
$writer = new \PhpOffice\PhpSpreadsheet\Writer\Csv($spreadsheet);
$writer->setUseBOM(true); // 防止中文在 Excel 中乱码
header('Content-Type: text/csv;charset=UTF-8');
header('Content-Disposition: attachment;filename="data.csv"');
$writer->save('php://output');
exit;

内存不足或超时导致导出失败怎么办

导出万级行数据时,默认配置容易触发 Fatal error: Allowed memory size exhaustedMaximum execution time exceeded。关键调整点:

  • 禁用公式预计算:$spreadsheet->setCalculateFormulae(false)
  • 关闭单元格缓存(改用 ISheet + setCellValueExplicit()
  • chunk 分批写入,避免一次性构造整个二维数组
  • 增加脚本限制:ini_set('memory_limit', '512M')set_time_limit(300)(仅限 CLI 或可信环境)

真正省内存的做法是:不用 fromArray(),而用循环 + setCellValueByColumnAndRow(),并配合 garbage_collect() 释放中间变量。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

161

2023.12.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

930

2023.08.02

require的用法
require的用法

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

507

2023.11.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

368

2023.10.25

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6511

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

840

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1088

2023.12.21

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

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

精品课程

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

共137课时 | 12.9万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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