PHPExcel读取多工作表

PHPExcel读取多工作表分享一个大神的人工智能教程 零基础 通俗易懂 风趣幽默 还带黄段子 希望你也加入到人工智能的队伍中来 点击查看教程 最近我们公司 crm 模块需要优化一下客户导入功能 之前的要求是 只需要从单个工作表中获取数据 现在的要求是 需要在多个工作表中获取对应数据 并导入数据库 幸亏 PHPExcel 已经给我们提供了获取多个 sheet 工作表的方法 下面直接上代码 这

       最近我们公司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 <= $sheetCount-1;$i++){//循环sheet工作表的总个数 $sheet = $objPHPExcel->getSheet($i); $highestRow = $sheet->getHighestRow(); $RowNum += $highestRow-1;//计算所有sheet的总行数 $highestColumn = $sheet->getHighestColumn(); //从第$i个sheet的第1行开始获取数据 for($row = 1;$row <= $highestRow;$row++){ //把每个sheet作为一个新的数组元素 键名以sheet的索引命名 利于后期数组的提取 $rowData[$i][] = arrToOne($sheet->rangeToArray('A' . $row . ':' . $highestColumn . $row, NULL, TRUE, FALSE)); } } /*删除每行表头数据*/ foreach($rowData as $k=>$v){ array_shift($rowData[$k]); } echo '
'; print_r($rowData);//打印结果 echo '

'; return array("RowNum" => $RowNum,"Excel_Data" => $rowData); }

Excel截图如下:

PHPExcel读取多工作表   

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

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

Array ( [0] => Array ( [0] => Array ( [0] => 测试数据001 [1] => [2] => 联系人1 [3] => 女 [4] => [5] => [6] => [7] => [8] => [9] => [10] => [11] => [12] => ) [1] => Array ( [0] => 测试数据002 [1] => [2] => 联系人2 [3] => 女 [4] => [5] => [6] => [7] => [8] => [9] => [10] => [11] => [12] => ) ) [1] => Array ( [0] => Array ( [0] => 测试数据014 [1] => [2] => 联系人13 [3] => 女 [4] => [5] => [6] => [7] => [8] => [9] => [10] => [11] => [12] => ) ) [2] => Array ( [0] => Array ( [0] => 测试数据015 [1] => [2] => 联系人13 [3] => 女 [4] => [5] => [6] => [7] => [8] => [9] => [10] => [11] => [12] => ) ) [3] => Array ( ) ) 

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206094.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午4:29
下一篇 2026年3月19日 下午4:30


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号