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

PHPExcel实现的读取多工作表操作示例

php 搞代码 4年前 (2022-01-01) 28次浏览 已收录 0个评论

这篇文章主要介绍了PHPExcel实现的读取多工作表操作,结合实例形式分析了PHPExcel针对Excel多个sheet工作表的读取、解析相关操作技巧,需要的朋友可以参考下

本文实例讲述了PHPExcel实现的读取多工作表操作。分享给大家供大家参考,具体如下:

最近我们公司crm模块需要优化一下客户导入功能,之前的要求是:只需要从单个工作表中获取数据;现在的要求是:需要在多个工作表中获取对应数据,并导入数据库;

幸亏PHPExcel已经给我们提供了获取多个sheet工作表的方法。下面直接上代码:【这里我用的是tp3.2.3】

 /** * 导入excel文件 * @param string $file excel文件路径 * @return array    excel文件内容数组 */ function import_excel($file){ // 判断文件是什么格式 $type = pathinfo($file); $type = strtolower($type["extension"]); if ($type=='xlsx') { $type='Excel2007'; }elseif($type=='xls') { $type = 'Excel5'; } ini_set('max_execution_time', '0'); Vendor('PHPExcel.PHPExcel'); $objReader = PHPExcel_IOFactory::createReader($type);//判断使用哪种格式 $objReader ->setReadDataOnly(true); //只读取数据,会智能忽略所有空白行,这点很重要!!! $objPHPExcel = $objReader->load($file); //加载Excel文件 $sheetCount = $objPHPExcel->getSheetCount();//获取sheet工作表总个数 $rowData = array(); $RowNum = 0; /*读取表格数据*/ for($i =0;$i getSheet($i); $highestRow = $sheet->getHighestRow(); $RowNum += $highestRow-1;//计算所有sheet的总行数 $highestColumn = $sheet->getHighestColumn(); //从第$i个sheet的第1行开始获取数据 for($row = 1;$row rangeToArray('A' . $row . ':' . $highestColumn . $row, NULL, TRUE, FALSE)); } } /*删除每行表头数据*/ foreach($rowData as $k=>$v){ array_shift($rowData[$k]); } echo '<pre class="prettyprint linenums">'; print_r($rowData);//打印结果 echo '

‘; return array(“RowNum” => $RowNum,”Excel_Data” => $rowData); }

Excel截图如下:

打印结果如下:0对应第一个sheet;以此类推第3个就是最后一个sheet;

注意:当某一个sheet不存在任何数据时,我这里会创建该元素为空数组,比如下面结果的第3个元素 ;所以在插入数据库操作的时候需要再判断一下是否为空!

Array<br /> (<br />     [0] => Array<br />         (<br />             [0] => Array<br />                 (<br />                     [0] => 测试数据001<br />                     [1] => <br />                     [2] => 联系人1<br />                     [3] => 女<br />                     [4] => <br />                     [5] => <br />                     [6] => <br />                     [7] => <br />                     [8] => <br />                     [9] => <br />                     [10] => <br />                     [11] => <br />                     [12] => <br />                 )<br />  <br />             [1] => Array<br />                 (<br />                     [0] => 测试数据002<br />                     [1] => <br />                     [2] => 联系人2<br />                     [3] => 女<br />                     [4] => <br />                     [5] => <br />                     [6] => <br />                     [7] => <br />                     [8] => <br />                     [9] => <br />                     [10] => <br />                     [11] => <br />                     [12] => <br />                 )<br />  <br />         )<br />  <br />     [1] => Array<br />         (<br />             [0] => Array<br />                 (<br />                     [0] => 测试数据014<br />                     [1] => <br />                     [2] => 联系人13<br />                     [3] => 女<br />                     [4] => <br />                     [5] => <br />                     [6] => <br />                     [7] => <br />                     [8] => <br />                     [9] => <br />                     [10] => <br />                     [11] => <br />                     [12] => <br />                 )<br />  <br />       <mark style="color:transparent">来源gaodaimacom搞#代%码网</mark>  )<br />  <br />     [2] => Array<br />         (<br />             [0] => Array<br />                 (<br />                     [0] => 测试数据015<br />                     [1] => <br />                     [2] => 联系人13<br />                     [3] => 女<br />                     [4] => <br />                     [5] => <br />                     [6] => <br />                     [7] => <br />                     [8] => <br />                     [9] => <br />                     [10] => <br />                     [11] => <br />                     [12] => <br />                 )<br />  <br />         )<br />  <br />     [3] => Array<br />         (<br />         )<br />  <br /> )<br />

至此, 以上就成功获取到了每一个sheet的数据;

PS:关于PHPExcel文件可至此下载 https://www.gaodaima.com/codes/194070.html。

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。

以上就是PHPExcel实现的读取多工作表操作示例的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHPExcel实现的读取多工作表操作示例

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

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

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

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