今天一个线上项目反应导入excel文件时,网页直接卡死,导入excel文件时失败,通过一步一步的验证发现是在读取excel文件时卡死,此项目使用的是phpoffice/phpexcel拓展,最后发现是在执行load方法加载excel文件时出现卡死,以前在导入excel文件一直是正常的,并且excel中的数据也不是不少,究竟是因为什么缘由形成的呢?php
最后在查找phpoffice/phpexcel官方文档中发现,这是因为excel文件中存在了某些特殊字符致使了加载excel文件时崩溃,既然找到了缘由,就必定有解决方法,在phpoffice/phpexcel中有一个属性能够解决此方法readDataOnly,此属性在拓展中默认时false,咱们须要将readDataOnly属性设置为trueexcel
$PHPExcel->setReadDataOnly(true); //过滤excel中的特殊字符
因此完整的读取excel的代码以下:code
$PHPExcel = new PHPExcel_Reader_Excel2007();
$file = 'excel文件';
try {
if (!$PHPExcel->canRead($file)) {
//默认用excel2007读取excel,若格式不对,则用以前的版本进行读取
$PHPExcel = new PHPExcel_Reader_Excel5();
}
$PHPExcel->setReadDataOnly(true); //过滤excel中的特殊字符
$excel = $PHPExcel->load($file);//加载excel
//读取excel文件中的第一个工做表
$currentSheet = $excel->getSheet(0);
} catch (Exception $e) {
throw new InvalidValueException('请选择正确的导入文件!');
}
$allRow = $currentSheet->getHighestRow() - 1; //获取excel总行数
//读取excel信息
for ($currentRow = 1; $currentRow <= $allRow; $currentRow++) {
//读取指定列数据0表示第一列
$currentSheet->getCellByColumnAndRow(0, $currentRow + 1)->getValue()
}