您现在的位置是:网站首页>>PHP>>php

使用phpoffice/phpexcel拓展读取excel内容卡死解决

发布时间:2020-11-11 11:46:48作者:wangjian浏览量:44点赞量:0

    今天一个线上项目反应导入excel文件时,网页直接卡死,导入excel文件时失败,经过一步一步的验证发现是在读取excel文件时卡死,此项目使用的是phpoffice/phpexcel拓展,最后发现是在执行load方法加载excel文件时出现卡死,之前在导入excel文件一直是正常的,而且excel中的数据也不是很多,到底是由于什么原因造成的呢?

    最后在查找phpoffice/phpexcel官方文档中发现,这是由于excel文件中存在了某些特殊字符导致了加载excel文件时崩溃,既然找到了原因,就一定有解决方法,在phpoffice/phpexcel中有一个属性可以解决此方法readDataOnly,此属性在拓展中默认时false,我们需要将readDataOnly属性设置为true

    $PHPExcel->setReadDataOnly(true);  //过滤excel中的特殊字符

    所以完整的读取excel的代码如下:

    $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()
    }


0 +1