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

今天一个线上项目反应导入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()

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值