• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用phpofficephpexcel拓展读取excel内容卡死解决

php 搞代码 3年前 (2022-03-01) 34次浏览 已收录 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()
}

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用phpofficephpexcel拓展读取excel内容卡死解决
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址