如何使用ThinkPHP实现Excel数据高效批量导入?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1182个文字,预计阅读时间需要5分钟。
不直接使用ThinkPHP的该类,而是它本身不内置Excel解析能力。官方仅提供数据库和请求处理,Excel导入依赖第三方库,如phpoffice/phpspreadsheet。通过composer require phpoffice/phpspreadsheet安装后,很多人遇到自动加载失败或命名空间错误等问题。
- 别用过时的
PHPExcel,已停止维护,ThinkPHP 6+ 的 PSR-4 自动加载和它不兼容 -
use PhpOffice\PhpSpreadsheet\IOFactory;必须写全,漏掉PhpOffice\前缀就报错 - 如果用的是 ThinkPHP 5.1,注意 PHP 版本不能低于 7.1;TP6 要求 PHP ≥ 7.2,而
phpspreadsheet1.20+ 需要 PHP 7.4+ - 上传文件后,别直接传
$_FILES['file']['tmp_name']给IOFactory::load()—— 它需要真实路径,且 PHP 进程要有读权限
怎么安全地读取上传的 Excel 并转成二维数组
核心是控制输入来源、限制格式、避免内存爆炸。直接 IOFactory::load($path) 读整个文件,在 10 万行 Excel 上可能吃光 512MB 内存。
本文共计1182个文字,预计阅读时间需要5分钟。
不直接使用ThinkPHP的该类,而是它本身不内置Excel解析能力。官方仅提供数据库和请求处理,Excel导入依赖第三方库,如phpoffice/phpspreadsheet。通过composer require phpoffice/phpspreadsheet安装后,很多人遇到自动加载失败或命名空间错误等问题。
- 别用过时的
PHPExcel,已停止维护,ThinkPHP 6+ 的 PSR-4 自动加载和它不兼容 -
use PhpOffice\PhpSpreadsheet\IOFactory;必须写全,漏掉PhpOffice\前缀就报错 - 如果用的是 ThinkPHP 5.1,注意 PHP 版本不能低于 7.1;TP6 要求 PHP ≥ 7.2,而
phpspreadsheet1.20+ 需要 PHP 7.4+ - 上传文件后,别直接传
$_FILES['file']['tmp_name']给IOFactory::load()—— 它需要真实路径,且 PHP 进程要有读权限
怎么安全地读取上传的 Excel 并转成二维数组
核心是控制输入来源、限制格式、避免内存爆炸。直接 IOFactory::load($path) 读整个文件,在 10 万行 Excel 上可能吃光 512MB 内存。

