问题如下
导入excel 报错Trying to access array offset on value of type int[/data/shopadminapi/extend/PHPExcel_1.8.0/Classes/PHPExcel/Cell/DefaultValueBinder.php:86]
这个错误是PHP 7.4及以上版本对非数组类型进行数组访问时的严格类型检查导致的。具体分析如下:
主要原因
PHPExcel已停止维护,与PHP 7.4+存在兼容性问题,当代码尝试将int/float等非数组类型当作数组访问时会触发此错误
DefaultValueBinder.php中未对$pValue进行类型检查就直接进行数组操作
解决方案
#### 推荐方案:迁移到PhpSpreadsheet(PHPExcel的现代替代品)
php
composer require phpoffice/phpspreadsheet
#### 临时修复方案(修改DefaultValueBinder.php):
php
// 修改前
} elseif ($pValue{0} === '=' && strlen($pValue) > 1) {
// 修改后
} elseif (is_string($pValue) && $pValue[0] === '=' && strlen($pValue) > 1) {
其他建议
该问题本质是PHPExcel已不兼容新版PHP的类型系统,最佳实践是升级到PhpSpreadsheet库.
在 PHP 中,pValue{0} 和 pValue[0] 早期均可用于字符串的字符访问,但两者存在语法风格和兼容性的关键差异:
🔍 核心区别总结
特性 | $pValue{0} | $pValue[0] |
---|---|---|
语法类型 | 花括号语法(Curly Brace) | 方括号语法(Square Bracket) |
官方建议 | ❌ 已废弃(Deprecated) | ✅ 推荐使用 |
兼容性 | ❌ PHP 7.4+ 警告;PHP 8.0+ 移除 | ✅ 所有版本支持 |
适用范围 | ❗️ 仅限字符串 | ✅ 字符串、数组、实现了ArrayAccess的对象 |
📌 详细说明
功能等价性(历史行为)
在旧版 PHP 中(如 PHP 5.x),两者均可访问字符串的第一个字符:
php
Copy Code
$str = "abc";
echo $str{0}; // 输出 "a"(旧版有效)
echo $str[0]; // 输出 "a"(始终有效)
废弃与移除时间线
PHP 7.4:$str{0} 语法被标记为废弃(Deprecated),使用时会触发 E_DEPRECATED 警告。
PHP 8.0:完全移除花括号语法,使用 $str{0} 会导致致命错误(Fatal Error)。
类型安全性差异
$pValue[0] 支持更多数据类型:
php
Copy Code
$arr = [10, 20, 30];
echo $arr[0]; // 输出 10(数组访问)
$pValue{0} 仅限字符串,若用于数组或整型等类型,会因类型不匹配报错(如 Trying to access array offset on value of type int)。
⚠️ 重要实践建议
一律使用 $pValue[0]
兼容所有 PHP 版本且符合现代编码规范,避免因语法废弃导致程序崩溃。
类型检查
若变量可能非字符串或数组,应先验证类型:
php
if (is_string($pValue) || is_array($pValue)) {
echo $pValue[0]; // 安全访问
}
升级代码
旧项目中发现 { } 语法需替换为 [ ],确保兼容 PHP 7.4+。
💎 示例对比
php
$str = "Hello";
// 正确写法(推荐)
echo $str[0]; // "H"
// 错误写法(PHP 8.0+ 崩溃)
echo $str{0}; // PHP 8.0 报错:Fatal Error
🌟 结论:$pValue[0] 是唯一应使用的语法,花括号访问方式已是历史遗留,新项目严禁使用,旧项目需优先替换。